學習筆記

          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 閱讀(254) 評論(0)  編輯  收藏


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


          網站導航:
           
          主站蜘蛛池模板: 五华县| 龙口市| 青海省| 开封县| 阿巴嘎旗| 泽普县| 阳信县| 大兴区| 全南县| 阿拉尔市| 东莞市| 安宁市| 两当县| 襄垣县| 永康市| 义乌市| 安平县| 佛坪县| 蒙阴县| 朔州市| 临沧市| 高淳县| 济宁市| 福安市| 东乌珠穆沁旗| 寿光市| 镇坪县| 五大连池市| 溧水县| 富蕴县| 双城市| 宣汉县| 迁西县| 玉山县| 鄯善县| 永清县| 定南县| 射阳县| 全椒县| 辽阳县| 宁城县|