隨筆 - 18  文章 - 0  trackbacks - 0
          <2010年2月>
          31123456
          78910111213
          14151617181920
          21222324252627
          28123456
          78910111213

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          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 2010-02-04 17:00 lucas_y 閱讀(177) 評論(0)  編輯  收藏 所屬分類: web

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


          網站導航:
           
          主站蜘蛛池模板: 双桥区| 定陶县| 宜君县| 潼关县| 高陵县| 万盛区| 尼木县| 漳浦县| 龙陵县| 佛学| 资讯 | 阳城县| 白城市| 黄冈市| 遂平县| 广丰县| 信宜市| 遂昌县| 沭阳县| 福鼎市| 汝阳县| 友谊县| 棋牌| 汕头市| 东阳市| 乌海市| 筠连县| 蒙城县| 乌拉特前旗| 镇赉县| 和平区| 三门峡市| 深泽县| 江山市| 宁远县| 扶风县| 霍林郭勒市| 靖州| 金昌市| 青河县| 积石山|