學習筆記

          Simple is beautiful.

          導航

          <2007年8月>
          2930311234
          567891011
          12131415161718
          19202122232425
          2627282930311
          2345678

          統計

          公告

          ...

          常用鏈接

          留言簿(1)

          隨筆分類(2)

          隨筆檔案(56)

          Weblog

          搜索

          最新評論

          評論排行榜

          JAVA反射機制

          JAVA反射機制
              JAVA反射機制是在運行狀態中,對于任意一個類,都能夠知道這個類的所有屬性和方法;對于任意一個對象,都能夠調用它的任意一個方法;這種動態獲取的信息以及動態調用對象的方法的功能稱為java語言的反射機制。
          Java反射機制主要提供了以下功能: 在運行時判斷任意一個對象所屬的類;在運行時構造任意一個類的對象;在運行時判斷任意一個類所具有的成員變量和方法;在運行時調用任意一個對象的方法;生成動態代理。
          1. 得到某個對象的屬性

          1 public Object getProperty(Object owner, String fieldName) throws Exception {
          2     Class ownerClass = owner.getClass();

          4     Field field = ownerClass.getField(fieldName);

          6     Object property = field.get(owner);

          8     return property;
          9 }
          Class ownerClass = owner.getClass():得到該對象的Class。

          Field field = ownerClass.getField(fieldName):通過Class得到類聲明的屬性。

          Object property = field.get(owner):通過對象得到該屬性的實例,如果這個屬性是非公有的,這里會報IllegalAccessException。

          2. 得到某個類的靜態屬性

           1 public Object getStaticProperty(String className, String fieldName)
           2             throws Exception {
           3     Class ownerClass = Class.forName(className);
           4 
           5     Field field = ownerClass.getField(fieldName);
           6 
           7     Object property = field.get(ownerClass);
           8 
           9     return property;
          10 }

          Class ownerClass = Class.forName(className) :首先得到這個類的Class。

          Field field = ownerClass.getField(fieldName):和上面一樣,通過Class得到類聲明的屬性。

          Object property = field.get(ownerClass) :這里和上面有些不同,因為該屬性是靜態的,所以直接從類的Class里取。

          3. 執行某對象的方法

           1 public Object invokeMethod(Object owner, String methodName, Object[] args) throws Exception {
           2 
           3     Class ownerClass = owner.getClass();
           4 
           5     Class[] argsClass = new Class[args.length];
           6 
           7     for (int i = 0, j = args.length; i < j; i++) {
           8         argsClass[i] = args[i].getClass();
           9     }
          10 
          11     Method method = ownerClass.getMethod(methodName, argsClass);
          12 
          13     return method.invoke(owner, args);
          14 }
          Class owner_class = owner.getClass() :首先還是必須得到這個對象的Class。

          5~9行:配置參數的Class數組,作為尋找Method的條件。

          Method method = ownerClass.getMethod(methodName, argsClass):通過Method名和參數的Class數組得到要執行的Method。

          method.invoke(owner, args):執行該Method,invoke方法的參數是執行這個方法的對象,和參數數組。返回值是Object,也既是該方法的返回值。

          4. 執行某個類的靜態方法

           1 public Object invokeStaticMethod(String className, String methodName,
           2             Object[] args) throws Exception {
           3     Class ownerClass = Class.forName(className);
           4 
           5     Class[] argsClass = new Class[args.length];
           6 
           7     for (int i = 0, j = args.length; i < j; i++) {
           8         argsClass[i] = args[i].getClass();
           9     }
          10 
          11     Method method = ownerClass.getMethod(methodName, argsClass);
          12 
          13     return method.invoke(null, args);
          14 }

          基本的原理和實例3相同,不同點是最后一行,invoke的一個參數是null,因為這是靜態方法,不需要借助實例運行。

          5. 新建實例
           1 
           2 public Object newInstance(String className, Object[] args) throws Exception {
           3     Class newoneClass = Class.forName(className);
           4 
           5     Class[] argsClass = new Class[args.length];
           6 
           7     for (int i = 0, j = args.length; i < j; i++) {
           8         argsClass[i] = args[i].getClass();
           9     }
          10 
          11     Constructor cons = newoneClass.getConstructor(argsClass);
          12 
          13     return cons.newInstance(args);
          14 
          15 }

          這里說的方法是執行帶參數的構造函數來新建實例的方法。如果不需要參數,可以直接使用newoneClass.newInstance()來實現。

          Class newoneClass = Class.forName(className):第一步,得到要構造的實例的Class。

          第5~第9行:得到參數的Class數組。

          Constructor cons = newoneClass.getConstructor(argsClass):得到構造子。

          cons.newInstance(args):新建實例。

          6. 判斷是否為某個類的實例

          1 public boolean isInstance(Object obj, Class cls) {
          2     return cls.isInstance(obj);
          3 }

          7. 得到數組中的某個元素
          1 public Object getByArray(Object array, int index) {
          2     return Array.get(array,index);
          3 }

          posted on 2007-08-30 00:24 Ecko 閱讀(250) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 连平县| 平邑县| 北碚区| 双江| 锡林浩特市| 德昌县| 巴南区| 郎溪县| 辽中县| 武邑县| 龙陵县| 南乐县| 行唐县| 辰溪县| 高淳县| 泾川县| 无为县| 广灵县| 濮阳市| 香港| 荆州市| 无极县| 扬州市| 和平县| 乐东| 衡水市| 康保县| 海门市| 闸北区| 静安区| 平潭县| 塔河县| 长兴县| 普兰店市| 当涂县| 道真| 巧家县| 长汀县| 米泉市| 澄迈县| 呼伦贝尔市|