リフレクション メカニズムは実行状態にあります。リフレクション メカニズムは、Java に「オブジェクトを操作する」機能を提供します。実行状態では、クラス ファイル オブジェクトを通じて、任意のクラスのプロパティ、メソッド、および構造体を操作できます。メソッド (プライベート メソッドを含む) は、リフレクション メカニズムの前にあるすべてのクラスに対して透過的です。
私自身の要約: このクラス内のすべては、Class ファイル オブジェクトを通じて見ることができ、使用および変更できます
リフレクションの前提は、クラス ファイル オブジェクト ((バイトコード オブジェクト)) を取得することです。その場合、それを取得するには 3 つの方法があります。
Class.forName ("完全なクラス名") ---- Class クラスの静的メソッド (最も一般的に使用される)
Class name.class
Object .getClass()
//方式1:获取字节码对象,Class.forName("全类名") Class cla1 = Class.forName("Study01.Person"); //方式2: 类名.Class Class cla2 = Person.class; //方式3:对象.getClass(); Person per = new Person(); Class cla3 = per.getClass(); //这三个class对象都是由Person这个类生成的 //那么我们看一下这三个字节码对象是不是同一个: System.out.println(cla1==cla2); System.out.println(cla2==cla3);
//出力結果: 2 true
結論:
バイトコード オブジェクトはクラスのロード時に生成され、存在するのは 1 つだけです。
public class Person { private String name; //名字 private int age = 18; //年龄 public int ID = 123; //身份证 public String Sex; //性别 @Override public String toString(){ return "姓名"+name+"年龄:"+age+"ID:"+ID+"性别:"+Sex; } }テスト クラス:
public class Test { public static void main(String[] args) throws ClassNotFoundException { //获取Class文件对象,用最常用的通过Class类的静态方法 Class per = Class.forName("Test01.Person"); //这里是传入全路径!!从最外层的包名开始! //使用getFields()方法获取全部被public修饰的属性(方法上面的截图有) //并且返回的是Field类型的数组 Field fields[] = per.getFields(); for (Field field:fields) { System.out.println(field); } } }出力 : Person クラスのすべてのパブリック属性を正常に取得しました。
2. プライベート属性を含むすべての属性を取得することもできます: (その他のコード)書き換えなし)
for (Field field : per.getDeclaredFields()) { System.out.println(field); }
出力:
3. パブリック属性を取得し、値を変更します:
Field f = per.getField("Sex"); System.out.println(f); //获取一个对象: Object obj = per.getConstructor().newInstance(); //修改值: f.set(obj,"男"); Person p = (Person)obj; System.out.println(p.Sex);
出力:
4. プライベート属性を取得して値を変更します: ここで、上で変更したパブリック属性の値を接続します:
Person p = (Person)obj; //获取公有字段并调用,并修改 Field f = per.getField("Sex"); //获取一个对象: Object obj = per.getConstructor().newInstance(); f.set(obj,"男"); //将Sex的属性修改成了 男 //调用私有的属性,并修改 f = per.getDeclaredField("name"); //在访问私有的属性的值之前,先要设置运行访问↓ //在访问之前忽略访问权限的检查,叫暴力反射 f.setAccessible(true); f.set(obj,"张三"); System.out.println("Person里面的信息是:"+p.toString()); } }
出力:
リフレクションを通じてクラス内のメソッド (パブリック、プライベート、コンストラクター) を取得します:
パーソン クラス:
public class Person { private String name; //名字 private int age = 18; //年龄 public int ID = 123; //身份证 public String Sex ; //性别 //构造: public Person() {} public Person(String name, int age, int ID, String sex) { this.name = name; this.age = age; this.ID = ID; Sex = sex; } //无参公有方法: public void eat(){ System.out.println("我会吃饭"); } //有参公有方法: public void eat(String food){ System.out.println("我在吃:"+food); } //有参私有方法 private void play(String name){ System.out.println(name+"在玩"); } }
テスト クラス:
public class Test { public static void main(String[] args) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException { //获取到Person以及父类Object里面的public方法: System.out.println("-----获取到Person以及父类Object里面的public方法↓-----"); for (Method method : Person.class.getMethods()) { System.out.println(method); System.out.println("方法名:"+ method.getName()); } //获取到Person里面的方法,包括私有 System.out.println("-----获取到Person里面的方法,包括私有↓-----"); for (Method method:Person.class.getDeclaredMethods()) { System.out.println(method.getName()+" "); } //按照方法名获取到Person中的eat方法: System.out.println("-----根据方法名获取到Person类中的eat方法↓-----"); Method earMethod1 = Person.class.getMethod("eat"); Person per = new Person(); //通过invoke(Object,param...)来调用指定的方法 earMethod1.invoke(per); //使用反射调用有参方法; System.out.println("-----使用反射调用有参方法(传入参数)↓-----"); Method earMethod2 = Person.class.getMethod("eat",String.class); earMethod2.invoke(per,"牛肉"); //通过暴力反射获取到私有的play方法: System.out.println("-----通过暴力反射获取到私有的play方法传入参数)↓-----"); Method earMethod3 = Person.class.getDeclaredMethod("play", String.class); //在访问私有的属性的方法之前,先要设置运行访问 earMethod3.setAccessible(true); earMethod3.invoke(per,"小王"); }
出力:
-----Person および親クラス Object のパブリック メソッドを取得します↓-----
public void Test02.Person.eat(java .lang .String)
メソッド名:eat
public void Test02.Person.eat()
メソッド名:eat
public Final void java.lang.Object.wait() throws java.lang .InterruptedException
メソッド名: wait
public Final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException
メソッド名: wait
publicfinalative void java.lang .Object .wait(long) は java.lang.InterruptedException をスローします
メソッド名: wait
public boolean java.lang.Object.equals(java.lang.Object)
メソッド名:equals
public java。 lang.String java.lang.Object.toString()
メソッド名: toString
publicnativeintjava.lang.Object.hashCode()
メソッド名:hashCode
publicfinalnativejava.lang .Class java.lang.Object.getClass()
メソッド名: getClass
publicfinalnativevoidjava.lang.Object.notify()
メソッド名:notify
publicfinalnativevoidjava. lang.Object.notifyAll()
メソッド名:notifyAll
以上がJava リフレクション メカニズム原理の分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。