-
Java中集合的泛型,是防止錯誤輸入的,只在編譯階段有效,繞過編譯就無效了; 驗證:我們可以通過方法的反射來操作,繞過編譯; 繞過編譯操作就繞過了泛型; 不能用foreach進行遍歷操作;查看全部
-
反射的操作都是編譯之后的操作=====查看全部
-
方法的反射操作; a1。print(10,20);方法的反射操作使用m對象來進行方法調用合a1.print調用的效果; 方法如果沒有返回值返回不聊了,有返回值返回集體的返回值;查看全部
-
1.要獲取一個方法就是獲取類的信息,獲取類的信息首先要獲取類的類類型; 2.獲取方法由名稱和參數列表來決定; getMethod獲取的事public的方法; getDelcaredMethod自己生命的方法。查看全部
-
構造函數也是對象; java.lang.Constructor中封裝了構造函數的信息; getConstructors獲取所有的public的構造函數; getDeclaredConstructors得到所有的構造函數;查看全部
-
成員變量也是對象; java.lang.reflect.Field Field類封裝了關于成員變量的操作; getFields()方法獲取的是所有的public的成員變量的信息; getDeclaredFields獲取的是該類自己聲明的成員變量的信息;查看全部
-
Class.forName() 1 表示類的類類型,還代表了動態加載類 2編譯時刻加載的類是靜態加載類,運行時加載類是動態加載查看全部
-
基本的數據類型對應的也有類類型,只要是在類中聲明的關鍵字都會有類類型(void) c.getName(); c.getSimpleName(); getMethods()獲取所有Public函數包括父類繼承過來的方法 遍歷Method[]查看全部
-
new創建對象是靜態加載類,在編譯時需要加載所有可能遇到的類(若有一個類有問題則均不可運行)(有一個出問題則全部用不了) 通過類的類類型生成實例創建該類對象,可以實現動態加載查看全部
-
萬事萬物皆對象 類是對象 java.lang.Class的實例對象(現在一個類名字是Class) 只有虛擬機可以創建Class實例對象 (1)Class c1=fool.class;任何一個類都是Class的實例對象。任何一個類都有一個隱含的靜態成員class c1 c2表示了Fool的類類型(class type)fool類本身是一個實例,萬事萬物皆對象類也是Class的實例對象,類的類類型 (2)Class c2=c1.getClaas(); (3)Class.forname(""); (4)Fool foo=(Foo)c1.newInstance();通過類的類類型創建該類的實例對象查看全部
-
通過反射了解集合泛型的本質 * 通過Class、Method來認識泛型的本質 1. ArrayList list = new ArrayList();//能放任何類型,因為沒有泛型 ArrayList<String> list1 = new ArrayList<String>();//只能放String類型 //list1.add("hello"); //list1.add(20);錯誤的,集合的泛型就是用來防止錯誤輸入的 Class c1 = list.getClass(); Class c2 = list1.getClass(); System.out.println(c1==c2);//反射的操作都是編譯之后的操作 /* * c1==c2 返回true,說明編譯之后,集合的泛型是去泛型化的!也就是說集合沒有泛型了! * Java中集合的泛型,是防止錯誤輸入的,只在編譯階段有效 * 繞過編譯就無效了 * 驗證:我們可以通過方法的反射操作,來繞過編譯 */ try { Method m = c2.getMethod("add", Object.class);//這里不要寫成String.class,不然無法向list1添加整型 m.invoke(list1, "hello"); m.invoke(list1, 20);//繞過編譯操作,就繞過了泛型 System.out.println(list1.size()); System.out.println(list1); /* for (String string : list1) { System.out.println(string); }*///現在不能這樣遍歷了,會有類型轉換錯誤。int不能轉化為String } catch (NoSuchMethodException e) { e.printStackTrace(); } 2.我們要區分編譯和運行。 反射操作:Class的操作、Method的操作、Field的操作都繞過了編譯,都是在運行時刻執行的。查看全部
-
方法的反射 如何獲取某個方法: 方法的名稱和方法的參數列表才能唯一決定某個方法 方法反射的操作: method.invoke(對象,參數列表) 1.獲取A類中的print(int,int)方法: ①要獲取一個方法就是獲取類的信息,獲取類的信息首先要獲取類的類類型 A a1=new A(); Class c= a1.getClass(); ②獲取方法 由名稱和參數列表來決定,getMethod獲取的是public方法,getDelcaredMethod獲取自己聲明的方法 Method m =c.getMethod(methodName,paramtypes);//paramtypes可以用數組的形式表示new Class[]{int.class,int.class},也可以直接列舉類類型 2.方法的反射操作:是用m對象來進行方法調用,和a1.print(10,20)調用的方法相同m.invoke(a1,new Object[]{10,20}) Object o=m.invoke(對象名,參數);//方法如果沒有返回值返回null,如果有返回值返回具體值,參數可用數組的方式表示,也可以直接列舉,沒有參數就不寫查看全部
-
類也是實例對象,是java.lang.Class類的實例對象可以用三種方式表示: 1、Class c1=類.class; 2、Class c2=類的實例對象.getClass(); 3、Class c3=null; c3=Class.forName("類所屬的包.類名"); 第三種方法需要先實例化一個變量,然后通過Class.forName("")賦值,但需try,catch處理, c1和c2、c3都代表了類的類類型,一個類只可能是Class類的一個實例對象。 我們稱類這個實例對象是這個類的類類型。 可以通過類的類類型創建該類的實例對象,該實例對象需要需無參構造方法。 例:Foo(類) foo(類的實例對象)=(Foo需強制轉換類型,一般為接口,便于轉換)c1.newInstance();查看全部
-
通過反射了解集合泛型的本質 * 通過Class、Method來認識泛型的本質 1. ArrayList list = new ArrayList();//能放任何類型,因為沒有泛型 ArrayList<String> list1 = new ArrayList<String>();//只能放String類型 //list1.add("hello"); //list1.add(20);錯誤的,集合的泛型就是用來防止錯誤輸入的 Class c1 = list.getClass(); Class c2 = list1.getClass(); System.out.println(c1==c2);//反射的操作都是編譯之后的操作 /* * c1==c2 返回true,說明編譯之后,集合的泛型是去泛型化的!也就是說集合沒有泛型了! * Java中集合的泛型,是防止錯誤輸入的,只在編譯階段有效 * 繞過編譯就無效了 * 驗證:我們可以通過方法的反射操作,來繞過編譯 */ try { Method m = c2.getMethod("add", Object.class);//這里不要寫成String.class,不然無法向list1添加整型 m.invoke(list1, "hello"); m.invoke(list1, 20);//繞過編譯操作,就繞過了泛型 System.out.println(list1.size()); System.out.println(list1); /* for (String string : list1) { System.out.println(string); }*///現在不能這樣遍歷了,會有類型轉換錯誤。int不能轉化為String } catch (NoSuchMethodException e) { e.printStackTrace(); } 2.我們要區分編譯和運行。 反射操作:Class的操作、Method的操作、Field的操作都繞過了編譯,都是在運行時刻執行的。查看全部
-
1)如何獲取某個方法 方法的名稱和方法的參數列表才能唯一決定某個方法 2)方法的反射的操作 method.invoke(對象,參數列表) 1. 要獲取一個方法,就是要獲取類的信息,獲取類的信息就先要獲取類的類類型 2. 獲取方法,由名稱和參數列表來決定。 假設有A類: class A{ public void print(int a,int b){ System.out.println(a+b); } } 則: A a1 = new A(); Class c = a1.getClass(); Method m = c.getMethod("print", int.class,int.class); m.invoke(a1, 10,20); 控制臺輸出結果:30查看全部
舉報
0/150
提交
取消