一粱锐、靜態(tài)加載 VS 動態(tài)加載
1.編譯時加載的類都是靜態(tài)加載類怜浅,運(yùn)行時加載的類為動態(tài)加載類
2.new出來的都是靜態(tài)加載類,在編譯時 需要實例的對象必須存在搀暑。
3.動態(tài)加載類通過Class.forName(”類的全路徑名”)就可以加載類跨琳,返回的是加載類的類類型脉让,通過該類的對象newInstance方法埠啃,就可以獲得這個對象的實例
二碴开、Java反射機(jī)制
Java反射機(jī)制——獲取成員變量&構(gòu)造函數(shù)
一、成員變量是java.lang.reflect.Field的對象
1博秫、Field類封裝了關(guān)于成員變量的操作
2潦牛、Field[] fs = c.getFields()方法獲取所有public的成員變量Field[]信息
3、c.getDeclaredFields獲取的是該類自己聲明的成員變量信息
4挡育、field.getType()獲得成員類型的類類型
5巴碗、field.getName()獲得成員的名稱
二、構(gòu)造函數(shù)是java.lang.Constructor類的對象
1即寒、通過Class.getConstructor()獲得Constructor[]所有公有構(gòu)造方法信息
2橡淆、建議getDeclaredConstructors()獲取自己聲明的構(gòu)造方法
3、Constructor.getName():String
4母赵、Constructor.getParameterTypes():Class[]
成員變量也是對象逸爵,是java.lang.reflect.Field的對象;
三凹嘲、方法的反射:
- 方法名稱加參數(shù)列表可以唯一確定一個方法
- 通過方法對象來實現(xiàn)方法的功能师倔,即把實例對象當(dāng)成參數(shù)傳給方法對象
Here is an example:
There is a class A:
class A{void printInfo(String s1, String s2){System.out.println(s1 + s2);}}
Implement the class:
A a = new A();
Class c = a.getClass();
Method m = c.getMethod("printInfo", String.class, String.class);
//getMethod方法只能獲得public方法
//getDeclaredMethod方法能獲得所有自己聲明的方法
//you can write the above code like following:
Method m = c.getMethod("printInfo", new Object[]{String.class,String.class});
Object o = m.invoke(a, "Hello ", "World!");//Here, o = null
//You can also write like:
Object o = m.invoke(a, new Object[]{"Hello ","World!"});
//The above code just like:
a.printInfo("Hello ","World!");
四、Java反射機(jī)制——通過反射了解集合泛型的本質(zhì)
1:反射的操作都是編譯之后的操作趋艘;就是運(yùn)行階段
2:java中集合的泛型是防止錯誤輸入的棚愤;只在編譯階段有效耍休,只要繞過編譯就無效啦
我們可以通過方法的反射來操作,繞過編譯
eg:
ArrayList list1=new ArrayList();
ArrayList<String> list2=new ArrayList<String>();
Class c1=list1.getClass();
Class c2=list2.getClass();
System.out.print(c1==c2);//true
Method m=c2.getMethod("add",Object.class);
m.invoke(list2,20);//向list2集合中添加一個int 型的值;繞過編譯
當(dāng)然是不能直接foreach list2集合的燃少,會報類型轉(zhuǎn)換錯誤