国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

JAVA反射

2019-11-11 06:43:00
字體:
來源:轉載
供稿:網友

類是程序的一部分,每個類都有一個Class對象,每當編寫并編譯了一個新類就會產生一個Class對象(保存在一個同名的.class文件中)。為了生成這個對象就要用到JVM 分析主要的類和方法

interface HasBatteries {}interface WaterPRoof {}interface Shoots {}class Toy { //Comment out the following default constructor //to see NoSuchMethodError from(*1*) Toy() { } Toy(int i) { }}class FancyToy extends Toy implements HasBatteries, Waterproof, Shoots { FancyToy() { super(1); }}public class ToyTest { static void printInfo(Class cc) { Print.print("Class name: " + cc.getName() + " is Interface ? [" + cc.isInterface() + "]"); //是否是接口 Print.print("Simple name: " + cc.getSimpleName()); //不好含包名的類名 Print.print("Canonical name : " + cc.getCanonicalName()); //全限定的類名 } public static void main(String[] args) { Class c = null; try { c = Class.forName("TypeInfomation.Demo.FancyToy"); } catch (ClassNotFoundException e) { Print.print("Can't find FancyToy"); System.exit(1); } Print.print(c); printInfo(c); Print.print(); for (Class face : c.getInterfaces()) { printInfo(face); Print.print(); } Class up = c.getSuperclass(); Object obj = null; try { //Requires default constructor: obj = up.newInstance(); } catch (InstantiationException e) { Print.print("Cannot instantiate"); System.exit(1); } catch (IllegalaccessException e) { Print.print("Cannot access"); System.exit(1); } printInfo(obj.getClass()); }}

一、Class類 所有的Class對象都屬于這個 類的一個static成員,Class對象和其他對象一樣,我們可以使用 Class.forName("Gum") 獲取并操作它的引用(這就是類加載器的工作), 從上面的代碼可以看到,getSuperclass()方法查詢其直接基類,這將返回用來進一步查詢的Class對象。由此,可以在運行時發現一個對象完整的類繼承結構

1、newInstance方法 Class的newInstance()實現“虛擬構造器”的一種途徑,虛擬構造器尋你生命”我不知道你的確切類型,但是無論如何要正確地創建自己”,代碼中的 up 只是一個Class引用,在編譯期不具備任何更進一步的類型信息,創建新實例時,會得到指向Toy對象的Object引用,可以轉型操作它。

二、動態代理 1、 Proxy.newProxyInstance()可以創建動態代理,這個方法需要一個類加載器(通常可以從已經被加載的對象中獲取類加載器,然后傳遞給它,下面代碼Interface.class.getClassLoader()也可以換成RealObject .class.getClassLoader()),一個你希望實現的接口列表(不是類或抽象類),以及InvacationHandler接口的一個實現 然后使用Methgod.invoke()將請求轉發給被代理對象,并傳入必須的參數

class DynamicProxyHandler implements InvocationHandler{ private Object proxied; public DynamicProxyHandler(Object proxied) { this.proxied = proxied; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { //proxy:對象的引用 ,method :被調用的方法 ,args:方法里面的參數 System.out.println("**** proxy: " + proxy.getClass() + ". method: " +method + ", args " + args); if (args !=null) for (Object arg : args) //方法里面的參數 System.out.println(" " + arg); return method.invoke(proxied,args); //通過方法調用 引用和參數,轉發調用 }}public class SimpleDynamicProxy { public static void consumer(Interface iface){ iface.doSomething(); iface.somethingElse("bonobo"); } public static void main(String[] args) { RealObject real = new RealObject();// consumer(real); //常用調用 //Insert a proxy and cal again: Interface proxy = (Interface) Proxy.newProxyInstance(Interface.class.getClassLoader(), new Class[]{Interface.class},new DynamicProxyHandler(real)); consumer(proxy); }}

2、javap 一個隨JDK發布的反編譯工具 命令行 到Cat.java所對應的Cat.class文件的位置 運行 javap -private Cat.class 可以反編譯源程序

3、沒有任何方式可以阻止反射到達并調用那些非公共訪問權限的方法

public class ModifyingPrivateFields { public static void main(String[] args) throws Exception { WithPrivateFinalField pf = new WithPrivateFinalField(); System.out.println(pf); Field f = pf.getClass().getDeclaredField("i"); f.setAccessible(true); System.out.println("f.getInt(pf): " + f.getInt(pf)); f.setInt(pf,47); System.out.println(pf); Print.print(); f =pf.getClass().getDeclaredField("s"); f.setAccessible(true); System.out.println("f.get(pf): "+f.get(pf)); f.set(pf,"you are totally safe"); System.out.println(pf); Print.print(); f = pf.getClass().getDeclaredField("s2"); f.setAccessible(true); System.out.println("f.get(pf): "+f.get(pf)); f.set(pf,"No,you're not!"); System.out.println(pf); }}class WithPrivateFinalField { private int i = 1; private final String s = " I'm totally safe"; private String s2 = "Am I safe?"; public String toString() { return "i = " + i + ", " + s + ", " + s2; }}

4、一篇很好的文章,滑動鼠標總數亂跑,COPY下

package cn.lee.demo; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.lang.reflect.TypeVariable; public class Main { /** * 為了看清楚Java反射部分代碼,所有異常我都最后拋出來給虛擬機處理! * @param args * @throws ClassNotFoundException * @throws InstantiationException * @throws IllegalAccessException * @throws InvocationTargetException * @throws IllegalArgumentException * @throws NoSuchFieldException * @throws SecurityException * @throws NoSuchMethodException */ public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException, SecurityException, NoSuchFieldException, NoSuchMethodException { // TODO Auto-generated method stub //Demo1. 通過Java反射機制得到類的包名和類名 Demo1(); System.out.println("==============================================="); //Demo2. 驗證所有的類都是Class類的實例對象 Demo2(); System.out.println("==============================================="); //Demo3. 通過Java反射機制,用Class 創建類對象[這也就是反射存在的意義所在],無參構造 Demo3(); System.out.println("==============================================="); //Demo4: 通過Java反射機制得到一個類的構造函數,并實現構造帶參實例對象 Demo4(); System.out.println("==============================================="); //Demo5: 通過Java反射機制操作成員變量, set 和 get Demo5(); System.out.println("==============================================="); //Demo6: 通過Java反射機制得到類的一些屬性: 繼承的接口,父類,函數信息,成員信息,類型等 Demo6(); System.out.println("==============================================="); //Demo7: 通過Java反射機制調用類中方法 Demo7(); System.out.println("==============================================="); //Demo8: 通過Java反射機制獲得類加載器 Demo8(); System.out.println("==============================================="); } /** * Demo1: 通過Java反射機制得到類的包名和類名 */ public static void Demo1() { Person person = new Person(); System.out.println("Demo1: 包名: " + person.getClass().getPackage().getName() + "," + "完整類名: " + person.getClass().getName()); } /** * Demo2: 驗證所有的類都是Class類的實例對象 * @throws ClassNotFoundException */ public static void Demo2() throws ClassNotFoundException { //定義兩個類型都未知的Class , 設置初值為null, 看看如何給它們賦值成Person類 Class<?> class1 = null; Class<?> class2 = null; //寫法1, 可能拋出 ClassNotFoundException [多用這個寫法] class1 = Class.forName("cn.lee.demo.Person"); System.out.println("Demo2:(寫法1) 包名: " + class1.getPackage().getName() + "," + "完整類名: " + class1.getName()); //寫法2 class2 = Person.class; System.out.println("Demo2:(寫法2) 包名: " + class2.getPackage().getName() + "," + "完整類名: " + class2.getName()); } /** * Demo3: 通過Java反射機制,用Class 創建類對象[這也就是反射存在的意義所在] * @throws ClassNotFoundException * @throws IllegalAccessException * @throws InstantiationException */ public static void Demo3() throws ClassNotFoundException, InstantiationException, IllegalAccessException { Class<?> class1 = null; class1 = Class.forName("cn.lee.demo.Person"); //由于這里不能帶參數,所以你要實例化的這個類Person,一定要有無參構造函數哈~ Person person = (Person) class1.newInstance(); person.setAge(20); person.setName("LeeFeng"); System.out.println("Demo3: " + person.getName() + " : " + person.getAge()); } /** * Demo4: 通過Java反射機制得到一個類的構造函數,并實現創建帶參實例對象 * @throws ClassNotFoundException * @throws InvocationTargetException * @throws IllegalAccessException * @throws InstantiationException * @throws IllegalArgumentException */ public static void Demo4() throws ClassNotFoundException, IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException { Class<?> class1 = null; Person person1 = null; Person person2 = null; class1 = Class.forName("cn.lee.demo.Person"); //得到一系列構造函數集合 Constructor<?>[] constructors = class1.getConstructors(); person1 = (Person) constructors[0].newInstance(); person1.setAge(30); person1.setName("leeFeng"); person2 = (Person) constructors[1].newInstance(20,"leeFeng"); System.out.println("Demo4: " + person1.getName() + " : " + person1.getAge() + " , " + person2.getName() + " : " + person2.getAge() ); } /** * Demo5: 通過Java反射機制操作成員變量, set 和 get * * @throws IllegalAccessException * @throws IllegalArgumentException * @throws NoSuchFieldException * @throws SecurityException * @throws InstantiationException * @throws ClassNotFoundException */ public static void Demo5() throws IllegalArgumentException, IllegalAccessException, SecurityException, NoSuchFieldException, InstantiationException, ClassNotFoundException { Class<?> class1 = null; class1 = Class.forName("cn.lee.demo.Person"); Object obj = class1.newInstance(); Field personNameField = class1.getDeclaredField("name"); personNameField.setAccessible(true); personNameField.set(obj, "胖虎先森"); System.out.println("Demo5: 修改屬性之后得到屬性變量的值:" + personNameField.get(obj)); } /** * Demo6: 通過Java反射機制得到類的一些屬性: 繼承的接口,父類,函數信息,成員信息,類型等 * @throws ClassNotFoundException */ public static void Demo6() throws ClassNotFoundException { Class<?> class1 = null; class1 = Class.forName("cn.lee.demo.SuperMan"); //取得父類名稱 Class<?> superClass = class1.getSuperclass(); System.out.println("Demo6: SuperMan類的父類名: " + superClass.getName()); System.out.println("==============================================="); Field[] fields = class1.getDeclaredFields(); for (int i = 0; i < fields.length; i++) { System.out.println("類中的成員: " + fields[i]); } System.out.println("==============================================="); //取得類方法 Method[] methods = class1.getDeclaredMethods(); for (int i = 0; i < methods.length; i++) { System.out.println("Demo6,取得SuperMan類的方法:"); System.out.println("函數名:" + methods[i].getName()); System.out.println("函數返回類型:" + methods[i].getReturnType()); System.out.println("函數訪問修飾符:" + Modifier.toString(methods[i].getModifiers())); System.out.println("函數代碼寫法: " + methods[i]); } System.out.println("==============================================="); //取得類實現的接口,因為接口類也屬于Class,所以得到接口中的方法也是一樣的方法得到哈 Class<?> interfaces[] = class1.getInterfaces(); for (int i = 0; i < interfaces.length; i++) { System.out.println("實現的接口類名: " + interfaces[i].getName() ); } } /** * Demo7: 通過Java反射機制調用類方法 * @throws ClassNotFoundException * @throws NoSuchMethodException * @throws SecurityException * @throws InvocationTargetException * @throws IllegalAccessException * @throws IllegalArgumentException * @throws InstantiationException */ public static void Demo7() throws ClassNotFoundException, SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException, InstantiationException { Class<?> class1 = null; class1 = Class.forName("cn.lee.demo.SuperMan"); System.out.println("Demo7: /n調用無參方法fly():"); Method method = class1.getMethod("fly"); method.invoke(class1.newInstance()); System.out.println("調用有參方法walk(int m):"); method = class1.getMethod("walk",int.class); method.invoke(class1.newInstance(),100); } /** * Demo8: 通過Java反射機制得到類加載器信息 * * 在java中有三種類類加載器。[這段資料網上截取] 1)Bootstrap ClassLoader 此加載器采用c++編寫,一般開發中很少見。 2)Extension ClassLoader 用來進行擴展類的加載,一般對應的是jre/lib/ext目錄中的類 3)AppClassLoader 加載classpath指定的類,是最常用的加載器。同時也是java中默認的加載器。 * * @throws ClassNotFoundException */ public static void Demo8() throws ClassNotFoundException { Class<?> class1 = null; class1 = Class.forName("cn.lee.demo.SuperMan"); String nameString = class1.getClassLoader().getClass().getName(); System.out.println("Demo8: 類加載器類名: " + nameString); } } /** * * @author xiaoyaomeng * */ class Person{ private int age; private String name; public Person(){ } public Person(int age, String name){ this.age = age; this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } } class SuperMan extends Person implements ActionInterface { private boolean BlueBriefs; public void fly() { System.out.println("超人會飛耶~~"); } public boolean isBlueBriefs() { return BlueBriefs; } public void setBlueBriefs(boolean blueBriefs) { BlueBriefs = blueBriefs; } @Override public void walk(int m) { // TODO Auto-generated method stub System.out.println("超人會走耶~~走了" + m + "米就走不動了!"); } } interface ActionInterface{ public void walk(int m); }

https://github.com/hengzhou/Rejection http://blog.csdn.net/ljphhj/article/details/12858767


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 砀山县| 穆棱市| 监利县| 南昌县| 固安县| 年辖:市辖区| 祁连县| 宁德市| 大同县| 黔西县| 太白县| 阿图什市| 昌平区| 庆阳市| 清新县| 南川市| 绥芬河市| 台州市| 桂东县| 西宁市| 张家口市| 武宣县| 依兰县| 安塞县| 沅江市| 台东县| 公主岭市| 石渠县| 泉州市| 大理市| 贵定县| 云龙县| 扬中市| 图片| 焦作市| 于田县| 科技| 奉新县| 广水市| 九龙县| 萨迦县|