Java的反射機制一起來看看
一、什么是反射機制?
反射就是運行時識別類的能力,在運行時可以獲得當前對象的類結(jié)構(gòu),動態(tài)創(chuàng)建類的實例,調(diào)用對象的方法等;
獲得Class類對象的三種方式:
方式一 :Class.forName(“類名”);
Class類的一個靜態(tài)方法forName 加載類獲得類對象 運行的類庫中沒有Person類,程序依然可以編譯。
Class cls = Class.forName("com.oracle.vo.Person");方式二: 類名.class
要求運行的類庫一定要有Person類
//編譯的字節(jié)碼文件中,會為每個類 定義一個靜態(tài)的屬性class 類型是Class類型 //會為每個類定義一個屬性,存儲自己類的類對象 Class cls = Person.class;
方式三: 對象.getClass()
要求運行的類庫中一定要有Person類 當持有了一個對象時,可以根據(jù)對象獲得其類對象
Person p = new Person(); //getClass方法是Object類的方法,所有的對象都有g(shù)etClass方法 Class cls = p.getClass();
二、Class類
API方法
1. getName() 獲得類對象對應(yīng)類的類名(全類名:包名+類名)
2. getSimpleName() 獲得類對象對應(yīng)類的類名
3. getPackage() 獲得類對象對應(yīng)類的包對象
try {
Class cls = Class.forName("com.oracle.vo.Person");
System.out.println(cls.getName());
System.out.println(cls.getSimpleName());
Package page = cls.getPackage();
System.out.println(page.getName());
} catch (ClassNotFoundException e) {
e.printStackTrace();
}4. getField(String name) 根據(jù)名字獲得能訪問的屬性。
5. getDeclaredField(String name) 根據(jù)名字獲得屬性。
6. getDeclaredFields() 獲得所有的屬性
7. getDeclaredMethod()
8. getDeclaredConstructor(Class... types) 根據(jù)參數(shù)列表獲得構(gòu)造器
9. newInstance() 通過無參構(gòu)造器創(chuàng)建對象
10. getSuperClass() 獲得父類的類對象
三、Package類
Package對象抽象為包
四、Field類
是屬性的抽象,F(xiàn)ield類的實例就是某個屬性,F(xiàn)ield類包括了屬性名、屬性類型、屬性值、修飾范圍等。
獲得屬性對象,主要的作用是對屬性進行賦值或取值的操作。
1. get(Object obj) 返回Object :獲得某個對象的屬性值。
2. setAccessible(boolean flag) : 設(shè)置屬性是否可訪問。
3. set(Object obj,Object value) : 設(shè)置屬性值
public static void main(String[] args) {
//獲得Person的類對象 ,獲得Person的Class對象
Person p = new Person();
p.setName("tom");
try {
Class cls = Class.forName("com.oracle.vo.Person");
//獲得Person類中所有的屬性
Field[] fields = cls.getFields();
//獲得Person類中的name屬性
Field field = cls.getDeclaredField("name");
System.out.println(field.getName());
//獲得 某個Person對象 的name屬性值
//field: Person類的name屬性
//設(shè)置這個屬性可訪問,忽略修飾范圍
field.setAccessible(true);
//設(shè)置p對象的name屬性值 為jack
field.set(p, "jack");
System.out.println(field.get(p));
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (NoSuchFieldException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}五、Method類
invoke(Object obj, Object ... args) 返回Object : 執(zhí)行method方法
public static void main(String[] args) {
//獲得Person的類對象 ,獲得Person的Class對象
Person p = new Person();
p.setName("tom");
try {
Class cls = Class.forName("com.oracle.vo.Person");
//獲得Person類的 method(String name) 方法對象
Method method1 = cls.getDeclaredMethod("method", String.class);
//獲得Person類的 method() 方法對象
Method method2 = cls.getDeclaredMethod("method");
//method(int i,String name) 方法對象
Method method3 = cls.getDeclaredMethod("method",int.class,String.class);
//獲得全部方法
Method[] methods = cls.getDeclaredMethods();
//獲得方法要作什么? 就是要調(diào)用方法
//obj參數(shù): 調(diào)用哪個對象的方法
method1.invoke(p, "abc");
System.out.println(method3.invoke(p, 10,"abcd"));
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}六、Constructor類
newInstance(Object ... args) 調(diào)用構(gòu)造器創(chuàng)建對象
public static void main(String[] args) {
//獲得Person的類對象 ,獲得Person的Class對象
Person p = new Person();
p.setName("tom");
try {
Class cls = Class.forName("com.oracle.vo.Person");
//獲得 public Person() 構(gòu)造器
Constructor constructor1 = cls.getDeclaredConstructor();
//public Person(String name, int age) 構(gòu)造器
Constructor constructor2 = cls.getDeclaredConstructor(String.class,int.class);
//獲得構(gòu)造器的作用,要調(diào)用構(gòu)造器創(chuàng)建對象
Object obj1 = constructor1.newInstance();
Object obj2 = constructor2.newInstance("tom",20);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
springboot2版本無法加載靜態(tài)資源問題解決
這篇文章主要介紹了springboot2版本無法加載靜態(tài)資源問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11
elasticsearch啟動警告無法鎖定JVM內(nèi)存
今天小編就為大家分享一篇關(guān)于elasticsearch啟動警告無法鎖定JVM內(nèi)存,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03
Java內(nèi)存模型與JVM運行時數(shù)據(jù)區(qū)的區(qū)別詳解
這篇文章主要介紹了Java內(nèi)存模型與JVM運行時數(shù)據(jù)區(qū)的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10

