-
獲取類類型 類名.class 對象.getClaa class.forName查看全部
-
通過new出來的person對象,是靜態加載類,在編譯的時候就會檢查所有的靜態加載類,如果沒有找到類,編譯失敗。通過Class.forName("")方式是動態加載類,編譯的時候不會去管你類的全路徑是否有此類。只有在程序執行的時候才會去檢查查看全部
-
每個java類都是java.lang.Class的實例對象,稱為類的類類型(class type),獲取類的類類型有3種方式,1.person.Class(通過每個類都有的靜態成員變量)2.person p1 = new person();p1.getClass();(通過類的實例對象獲取類的類類型)3.Class c1 = Class.forName("類的全路徑");(通過類的全路徑獲取類的類類型)。獲取到類的類類型后,可以創建類的實例對象。通過newInstance()方法,需要強轉。查看全部
-
class對象三種獲取方式 1.Class c1= A.class; 2.Class c2=a.getClass() 3.Class c3 = forNameClass(pakcage.A) 反射機制是在編譯后的 所以可以繞過標準 所有的new 對象都是靜態編譯過程,就是必須編譯時會檢查 invoke方法是反射操作的核心 Mothed m = c1.getMethod(方法名 ,參數列表) m.invoke(代理的對象, 參數)查看全部
-
泛型只在編譯階段起作用,是為了防止錯誤輸入 通過方法的反射可以繞過編譯,繞過泛型查看全部
-
new是靜態加載類,要使用動態加載類:class.forname("") 而且,應該用接口來統一標準,然后用具體應用實現這個接口查看全部
-
方法的反射查看全部
-
getMethods查看全部
-
類全部信息查看全部
-
new創建對象 是靜態加載 在創建時就要加載所有可能用到的類查看全部
-
動態加載類查看全部
-
class查看全部
-
方法的反射操作:用method方法對象a來調用方法a(相當于實例一個類A對象,再A.a();) A a= new A(); Class at = a.getClass(); Method m = at.getMethod("print",int.class,int.class);//print(int a.int b){println(a+b);} m.invoke(a,1,2); 3查看全部
-
獲取方法信息: 基本數據類型,void關鍵字都存在類類型 class.getMethods()方法獲取是該類的所有public方法,包括從父類繼承的方法; class.getDeclareMethods()方法獲取該類自行聲明的所有方法,不論訪問權限; method.getName()獲取方法名 method.getReturnType()獲取方法的返回值 method.getParameterTypes(),獲取方法的參數類型的類類型數組class[] 三獲取方法信息: 一、基本的數據類型,void關鍵字等都存在類類型 Class c = 基類.class (int,String,double,void等) 二、Class類的基本API操作的 1、c.getName()可以獲取類的名稱 2、c.getSimpleName();//不包含包名的類的名稱 3、c.getMethods()獲取類的【public方法】集合,【包括繼承來的】 ***注意【所有方法都是Method類的對象】 4、c.getDeclaredMethods()獲取的是所有該類【自己聲明】的方法,【不問訪問權限】 三、Method類提供了一些操作方法的方法 1、.getReturnType()得到該方法的返回值類型的類類型(class),如int.class String.class 2、.getName()得到方法的名稱 3、.getParameterTypes()獲得參數列表類型的類類型,如參數為(int,int)則得到 Class c1 = int.class; int的類類型 Class c2 = String.class; String類的類類型 String類字節碼 Class c3 = double.class; double這個數據類類型的字節碼表示方式 Class c4 = Double.class; Double這個類的類類型字節碼表示方式 Class c5 = void.class; 表達了void這個類的類類型 getName為這個類的類類型的具體名稱 c1.getName ---> int c2.getName ---> java.lang.String 類的全稱 c2.getSimpleName ---> String 不包含包名的類的名稱查看全部
-
動態加載類:(利用動態加載類可以實現類方法的隨時檢測,不用全都寫完再編譯,因為Class a = new A()在編譯時) 創建一個A類,再創建一個檢測類,檢測類如果包含沒有創建過的B類的方法,運行時編譯就會報錯。 方法:新建一個接口,A繼承它,新建一個類,用反射技術通過一個類的名字得到其類類型at,然后Interface a = (Interface)ai.newInstance();來實例化,這樣就可以在不實現B的情況下實現A查看全部
舉報
0/150
提交
取消