-
功能性的類一般使用動態加載,而不要使用靜態加載。 動態加載:運行時加載(Class c = Class .forName();Foo foo = (Foo)c.newInstance(); 定義一個接口,不同類型的對象可以實現該接口,以確保動態加載類時強轉類型的一致性; 靜態加載:編譯時加載(用new創建對象是靜態加載類)查看全部
-
一、如何獲取某個方法:方法的【名稱】和【方法的參數列表】才能【唯一確定】某個方法 1、要獲取一個類的某個方法,需要先得到類類型 2、通過Class.getMethod(name,parameterTypes)獲得public的該方法:如c.getMethod("print",new Class[]{int.class,int.class})或者參數寫成int,int; ——> 來獲取 public void print(int a,int b) 3、同樣getDeclaredMethdo(name,paramterTypes)獲得自己聲明的該方法 二:方法的反射操作;就是用method對象進行方法調用;當然還是需要傳參的 method.invoke(對象實例,參數列表) 2.1:invoke(user,new Object[]{10,20})倘若沒有參數就可省略:invoke(user) 2.2:invoke(user,10,20)//直接傳參查看全部
-
類是對象查看全部
-
Java反射機制——獲取成員變量&構造函數 一、成員變量是java.lang.reflect.Field的對象 1、Field類封裝了關于成員變量的操作 2、Field[] fs = c.getFields()方法獲取所有public的成員變量Field[]信息 3、c.getDeclaredFields獲取的是該類自己聲明的成員變量信息 4、field.getType()獲得成員類型的類類型 5、field.getName()獲得成員的名稱 二、構造函數是java.lang.Constructor類的對象 1、通過Class.getConstructor()獲得Constructor[]所有公有構造方法信息 2、建議getDeclaredConstructors()獲取自己聲明的構造方法 3、Constructor.getName():String 4、Constructor.getParameterTypes():Class[] 成員變量也是對象,是java.lang.reflect.Field的對象;查看全部
-
Java反射機制——通過反射了解集合泛型的本質 1:反射的操作都是編譯之后的操作;就是運行階段 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 型的值;繞過編譯 當然是不能直接foreach list2集合的,會報類型轉換錯誤查看全部
-
Class類動態加載類的用法 動態類加載 Class.forNaame("類的全稱"):類的類類型 動態加載類 編譯時刻加載類是靜態加載類,運行時刻加載類是動態加載類 new 創建的對象,是靜態加載類,在編譯時刻就需要加載所有有可能使用到的類。 動態加載類,在運行時加載。 通過動態加載類可以做到 用哪個就加載哪個,不用不加載,是運行時加載 Class c = Class.forName(args[0]); 返回了這個加載類的類類型 new創建對象,是靜態加載類,在編譯時刻就需要加載所有的可能使用到的類??赡艹霈F編譯時錯誤; 通過動態加載類可解決該問題。不會出現編譯錯誤,只可能發生運行時錯誤。 動態加載類,在運行時加載。動態加載類可實現接口,繼承接口特性,這樣方便維護,實現更新補丁等功能。 class OfficeBetter{ public static void main(String[] args)throws Exception{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); //通過類類型,創建該對象 //try-catch捕捉異常 oa.start(); } } Interface OfficeAble{// 接口,作為Word和Excel的結構 public void start(); //抽象方法 } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } Word類--編譯時刻(此時Excel類沒創建):javac Word.java javac OfficeBetter.java //不需要重新編譯javac Office.java java OfficeBetter Word //運行結果:word...start... Excel類編譯,同上。查看全部
-
1)在面向對象的世界里,萬事萬物皆對象。 類是對象,類是java.lang.Class類的實例對象。 There is a class named Class 2)//Foo的實例對象如何表示 Foo foo1=new Foo();//foo1就表示出來了 //Foo這個類也是一個實例對象,Class類的實例對象,如何表示呢? //任何一個類都是Class的實例對象,這個實例對象有三種表示方式 //第一種表示方式--->實際在告訴我們任何一個類都有一個隱含的靜態成員變量class Class c1=Foo.class; //第二種表達方式--->已經知道該類的對象通過getClassF方法 Class c2=foo1.getClass(); //官網c1,c2表示了Foo類的類類型(class type),萬事萬物皆對象,類也是對象,是Class類的實例對象 //這個對象我們稱為該類的類類型 //不管c1 or c2都代表了Foo類的類類型,一個類只可能是Class類的一個實例對象 //第三種表達方式 Class c3=null; c3=Class.forName("com.imooc.reflect.Foo"); //我們完全可以通過類的類類型創建類的對象實例--->通過c1 or c2 or c3創建Foo的實例對象 Foo foo=(Foo)c1.newInstance();//需要有無參數的構造方法查看全部
-
Java反射機制——獲取成員變量&構造函數 一、成員變量是java.lang.reflect.Field的對象 1、Field類封裝了關于成員變量的操作 2、Field[] fs = c.getFields()方法獲取所有public的成員變量Field[]信息 3、c.getDeclaredFields獲取的是該類自己聲明的成員變量信息 4、field.getType()獲得成員類型的類類型 5、field.getName()獲得成員的名稱 二、構造函數是java.lang.Constructor類的對象 1、通過Class.getConstructor()獲得Constructor[]所有公有構造方法信息 2、建議getDeclaredConstructors()獲取自己聲明的構造方法 3、Constructor.getName():String 4、Constructor.getParameterTypes():Class[] 成員變量也是對象,是java.lang.reflect.Field的對象;查看全部
-
只要在類里面聲明的都有類類型 public static void pringClassMessage(Object object){ //要獲取類的信息,首先要獲取類的類型 Class c=object.getClass();//傳遞的是哪個子類的對象,c就是該子類的類類型 //獲取類的名稱 System.out.println("類的名稱是:"+c.getName()); /* * Method類,方法對象 * 一個成員方法就是一個Method對象 * getMethods()方法獲取的是所有public函數,包括父類繼承而來的 * getDeclaredMethods()獲取的是所有該類自己聲明的方法,不問訪問權限 * */ Method[] ms=c.getMethods();//c.getDeclaredMethods(); for (int i = 0; i < ms.length; i++) { //得到方法的返回值類型的類類型 Class returnType=ms[i].getReturnType(); System.out.println(returnType.getName()); //得到方法名 System.out.println(ms[i].getName()+"("); //獲取參數類型-->得到的是參數列表的類型的類類型 Class[] paramType=ms[i].getParameterTypes(); for (Class class1: paramType) { System.out.println(class1.getName()+","); } System.out.println(")"); } } }查看全部
-
一、如何獲取某個方法:方法的【名稱】和【方法的參數列表】才能【唯一確定】某個方法 1、要獲取一個類的某個方法,需要先得到類類型 2、通過Class.getMethod(name,parameterTypes)獲得public的該方法:如c.getMethod("print",new Class[]{int.class,int.class})或者參數寫成int,int; ——> 來獲取 public void print(int a,int b) 3、同樣getDeclaredMethdo(name,paramterTypes)獲得自己聲明的該方法 二:方法的反射操作;就是用method對象進行方法調用;當然還是需要傳參的 method.invoke(對象實例,參數列表) 2.1:invoke(user,new Object[]{10,20})倘若沒有參數就可省略:invoke(user) 2.2:invoke(user,10,20)//直接傳參查看全部
-
Class類動態加載類的用法 動態類加載 Class.forNaame("類的全稱"):類的類類型 動態加載類 編譯時刻加載類是靜態加載類,運行時刻加載類是動態加載類 new 創建的對象,是靜態加載類,在編譯時刻就需要加載所有有可能使用到的類。 動態加載類,在運行時加載。 通過動態加載類可以做到 用哪個就加載哪個,不用不加載,是運行時加載 Class c = Class.forName(args[0]); 返回了這個加載類的類類型 new創建對象,是靜態加載類,在編譯時刻就需要加載所有的可能使用到的類??赡艹霈F編譯時錯誤; 通過動態加載類可解決該問題。不會出現編譯錯誤,只可能發生運行時錯誤。 動態加載類,在運行時加載。動態加載類可實現接口,繼承接口特性,這樣方便維護,實現更新補丁等功能。 class OfficeBetter{ public static void main(String[] args)throws Exception{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); //通過類類型,創建該對象 //try-catch捕捉異常 oa.start(); } } Interface OfficeAble{// 接口,作為Word和Excel的結構 public void start(); //抽象方法 } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } Word類--編譯時刻(此時Excel類沒創建):javac Word.java javac OfficeBetter.java //不需要重新編譯javac Office.java java OfficeBetter Word //運行結果:word...start... Excel類編譯,同上。查看全部
-
Class類動態加載類的用法 動態類加載 Class.forNaame("類的全稱"):類的類類型 動態加載類 編譯時刻加載類是靜態加載類,運行時刻加載類是動態加載類 new 創建的對象,是靜態加載類,在編譯時刻就需要加載所有有可能使用到的類。 動態加載類,在運行時加載。 通過動態加載類可以做到 用哪個就加載哪個,不用不加載,是運行時加載 Class c = Class.forName(args[0]); 返回了這個加載類的類類型 new創建對象,是靜態加載類,在編譯時刻就需要加載所有的可能使用到的類??赡艹霈F編譯時錯誤; 通過動態加載類可解決該問題。不會出現編譯錯誤,只可能發生運行時錯誤。 動態加載類,在運行時加載。動態加載類可實現接口,繼承接口特性,這樣方便維護,實現更新補丁等功能。 class OfficeBetter{ public static void main(String[] args)throws Exception{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); //通過類類型,創建該對象 //try-catch捕捉異常 oa.start(); } } Interface OfficeAble{// 接口,作為Word和Excel的結構 public void start(); //抽象方法 } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } class Excel implements OfficeAble{ public void start(){ System.out.println("Excel...start..."); } } Word類--編譯時刻(此時Excel類沒創建):javac Word.java javac OfficeBetter.java //不需要重新編譯javac Office.java java OfficeBetter Word //運行結果:word...start... Excel類編譯,同上。查看全部
-
1)在面向對象的世界里,萬事萬物皆對象。 類是對象,類是java.lang.Class類的實例對象。 There is a class named Class 2)//Foo的實例對象如何表示 Foo foo1=new Foo();//foo1就表示出來了 //Foo這個類也是一個實例對象,Class類的實例對象,如何表示呢? //任何一個類都是Class的實例對象,這個實例對象有三種表示方式 //第一種表示方式--->實際在告訴我們任何一個類都有一個隱含的靜態成員變量class Class c1=Foo.class; //第二種表達方式--->已經知道該類的對象通過getClassF方法 Class c2=foo1.getClass(); //官網c1,c2表示了Foo類的類類型(class type),萬事萬物皆對象,類也是對象,是Class類的實例對象 //這個對象我們稱為該類的類類型 //不管c1 or c2都代表了Foo類的類類型,一個類只可能是Class類的一個實例對象 //第三種表達方式 Class c3=null; c3=Class.forName("com.imooc.reflect.Foo"); //我們完全可以通過類的類類型創建類的對象實例--->通過c1 or c2 or c3創建Foo的實例對象 Foo foo=(Foo)c1.newInstance();//需要有無參數的構造方法查看全部
-
集合泛型說明查看全部
-
1)在面向對象的世界里,萬事萬物皆對象。 類是對象,類是java.lang.Class類的實例對象。 There is a class named Class 2)//Foo的實例對象如何表示 Foo foo1=new Foo();//foo1就表示出來了 //Foo這個類也是一個實例對象,Class類的實例對象,如何表示呢? //任何一個類都是Class的實例對象,這個實例對象有三種表示方式 //第一種表示方式--->實際在告訴我們任何一個類都有一個隱含的靜態成員變量class Class c1=Foo.class; //第二種表達方式--->已經知道該類的對象通過getClassF方法 Class c2=foo1.getClass(); //官網c1,c2表示了Foo類的類類型(class type),萬事萬物皆對象,類也是對象,是Class類的實例對象 //這個對象我們稱為該類的類類型 //不管c1 or c2都代表了Foo類的類類型,一個類只可能是Class類的一個實例對象 //第三種表達方式 Class c3=null; c3=Class.forName("com.imooc.reflect.Foo"); //我們完全可以通過類的類類型創建類的對象實例--->通過c1 or c2 or c3創建Foo的實例對象 Foo foo=(Foo)c1.newInstance();//需要有無參數的構造方法查看全部
舉報
0/150
提交
取消