posts - 75,comments - 83,trackbacks - 0
          <2008年8月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          常用鏈接

          留言簿(6)

          隨筆分類(52)

          隨筆檔案(75)

          文章分類(12)

          文章檔案(15)

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

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

          1?public?Object?getProperty(Object?owner,?String?fieldName)?throws?Exception?{
          2?????Class?ownerClass?=?owner.getClass();
          3?
          4?????Field?field?=?ownerClass.getField(fieldName);
          5?
          6?????Object?property?=?field.get(owner);
          7?
          8?????return?property;
          9?}
          Class?ownerClass?=?owner.getClass():得到該對象的Class。

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

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

          2.?得到某個類的靜態(tài)屬性

          ?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)?:這里和上面有些不同,因為該屬性是靜態(tài)的,所以直接從類的Class里取。

          3.?執(zhí)行某對象的方法

          ?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行:配置參數(shù)的Class數(shù)組,作為尋找Method的條件。

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

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

          4.?執(zhí)行某個類的靜態(tài)方法

          ?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的一個參數(shù)是null,因為這是靜態(tài)方法,不需要借助實例運行。

          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?}

          這里說的方法是執(zhí)行帶參數(shù)的構(gòu)造函數(shù)來新建實例的方法。如果不需要參數(shù),可以直接使用newoneClass.newInstance()來實現(xiàn)。

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

          第5~第9行:得到參數(shù)的Class數(shù)組。

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

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

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

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

          7.?得到數(shù)組中的某個元素
          1?public?Object?getByArray(Object?array,?int?index)?{
          2?????return?Array.get(array,index);
          3?}
          posted on 2008-08-11 11:23 梓楓 閱讀(240) 評論(0)  編輯  收藏 所屬分類: java
          主站蜘蛛池模板: 永川市| 斗六市| 南漳县| 南和县| 泸州市| 九龙城区| 侯马市| 伊宁市| 夏邑县| 尖扎县| 深圳市| 浦城县| 祁东县| 昭平县| 信宜市| 宁蒗| 长沙县| 沈丘县| 迭部县| 铁力市| 上思县| 芒康县| 锦屏县| 丰台区| 克山县| 泰州市| 阿城市| 利津县| 宁国市| 旬邑县| 曲阳县| 札达县| 濮阳县| 满洲里市| 北海市| 天津市| 莱芜市| 凤冈县| 南涧| 陆河县| 剑川县|