本文实例讲述了Java编程反射机制用法。分享给大家供大家参考,具体如下:
前言:反射:动态获取类 (字节码文件 如本篇中的Person.class),并对其成员进行运行。反射在Android应用层的开发中可能遇到会稍微少一点,但对于想打通底层的小伙伴来说,必须要熟练掌握运用。
实体类
Person.java
package com.sunwenou.reflect;// 包名 public class Person { private String name; private int age; public Person() {// 无参 } public Person(String name, int age) {// 带参 super(); this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return name+","+age; } public void show() { // 空参 System.out.println("show"); } public void fun(String ss) { // 带参 System.out.println(ss); } public static void function() { // 静态 System.out.println("static"); } }
动态获取字节码文件的方法
本篇中为使博文看起来简洁,一概抛出Exception,并省略import,下同。
package com.sunwenou.reflect; public class Demo1 { /** * 动态获取字节码文件的方法 * 1:使用Object类提供的 Class getClass()方法 * 这种方法需要对象 * 2:每种数据类型都有一个静态的class属性,这个属性返回的这种数据类型所属字节码文件对象 * int.class Person.class * 3:使用 Class提供的 forName()方法 * 只需要提供一个字符串,这个字符串由 包名+类名 构成 */ public static void main(String[] args) throws Exception { //getClaz(); //getCalz2(); getClaz3(); } //使用 Class提供的 forName()方法 public static void getClaz3() throws Exception { Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); Class<?> claz2 = Class.forName("com.sunwenou.reflect.Person"); System.out.println(claz==claz2); } //每种数据类型都有一个静态的class属性 public static void getCalz2() { Class<Person> p1 = Person.class; Class<Person> p2 = Person.class; System.out.println(p1==p2); } //使用Object类提供的 Class getClass()方法 public static void getClaz() { Person person1 = new Person(); Class<? extends Person> claz = person1.getClass();//Person.class Person person2 = new Person(); Class<? extends Person> claz2 = person2.getClass();//Person.class System.out.println(claz==claz2); } }
动态获取类,并创建对象
package com.sunwenou.reflect; public class Demo2 { public static void main(String[] args) throws Exception { //createObj(); createObj2(); } public static void createObj2() throws Exception { //Person person = new Person("lisi",23); //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person");//Person.class //得到带参数的构造方法所属的Constructor类型的对象 Constructor constructor = claz.getConstructor(String.class,int.class); //使用Constructor类提供的创建对象的方法创建对象 Person person = (Person)constructor.newInstance("lisi",23); System.out.println(person); } public static void createObj() throws Exception { //Person person = new Person(); //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); Object obj = claz.newInstance();//默认使用空参的构造方法创建对象 System.out.println(obj); } }
动态获取类并为成员变量赋值
package com.sunwenou.reflect; public class Demo3 { public static void main(String[] args) throws Exception { //Person p = new Person(); //p.name = "lisi"; //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); //得到成员变量所属的Field类型的对象 //Field field = claz.getField("name");//得到的是public权限的成员 Field field = claz.getDeclaredField("name");//得到所有声明的字段 System.out.println(field); //非静态成员变量是依赖于对象的 Object obj = claz.newInstance(); field.setAccessible(true);//暴力破解, 设置为可访问的 field.set(obj, "张三"); System.out.println(obj); } }
动态获取类,并执行方法
package com.sunwenou.reflect; public class Demo4 { public static void main(String[] args) throws Exception { //method1(); method2(); method3(); } public static void method3() throws Exception { //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); Method m = claz.getMethod("function", null); m.invoke(null, null); } ////执行带参数的方法 public static void method2() throws Exception { //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); Method m = claz.getMethod("fun", String.class); Object obj = claz.newInstance(); m.invoke(obj, "hello"); } //执行无参的方法 public static void method1() throws Exception { //Person person = new Person(); person.show(); //得到字节码文件对象 Class<?> claz = Class.forName("com.sunwenou.reflect.Person"); //得到被执行的方法所属的字节码文件对象 Method m = claz.getMethod("show", null); //非静态方法是依赖于对象的 Object obj = claz.newInstance(); //执行方法 m.invoke(obj, null); } }
这就是反射的基本用法,我们就可以在不能通过正常创建对象的时候通过对象的字节码文件来创建对象,并执行其中的方法,你学会了吗??
更多关于java相关内容感兴趣的读者可查看本站专题:《Java面向对象程序设计入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
本文向大家介绍PHP反射机制用法实例,包括了PHP反射机制用法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP反射机制的用法,分享给大家供大家参考之用。具体方法如下: 演示示例代码如下所示: 输出结果: In Class One 可见,通过代理类ClassOneDelegator来代替ClassOne类来实现他的方法。 同样的,如下的代码也是能够运行的: 希望本文所述对大家的PH
本文向大家介绍JAVA反射机制实例详解,包括了JAVA反射机制实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了JAVA反射机制。分享给大家供大家参考,具体如下: 反射,当时经常听他们说,自己也看过一些资料,也可能在设计模式中使用过,但是感觉对它没有一个较深入的了解,这次重新学习了一下,感觉还行吧! 一、先看一下反射的概念: 主要是指程序可以访问,检测和修改它本身状态或行为的一种能力
本文向大家介绍Java 反射机制的实例详解,包括了Java 反射机制的实例详解的使用技巧和注意事项,需要的朋友参考一下 Java 反射机制的实例详解 前言 今天介绍下Java的反射机制,以前我们获取一个类的实例都是使用new一个实例出来。那样太low了,今天跟我一起来学习学习一种更加高大上的方式来实现。 正文 Java反射机制定义 Java反射机制是指在运行状态中,对于任意一个类,都能够知道这个类
Java 反射机制可以让我们在编译期(Compile Time)之外的运行期(Runtime)检查类,接口,变量以及方法的信息。反射还可以让我们在运行期实例化对象,调用方法,通过调用 get/set 方法获取变量的值。
本文向大家介绍java 反射机制,包括了java 反射机制的使用技巧和注意事项,需要的朋友参考一下 本文导引: 通过反射机制 获取类的基本信息 获取类的注解信息 获取泛型信息 output: 下面的例子,是通过反射机制获取类的注解信息。 output: 下面的例子,是通过反射机制获取泛型信息 output: 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多
本文向大家介绍简单总结Java的反射机制的运用,包括了简单总结Java的反射机制的运用的使用技巧和注意事项,需要的朋友参考一下 Java 的反射机制是使其具有动态特性的非常关键的一种机制,也是在JavaBean 中广泛应用的一种特性。 简单来说,一个类或者一个对象是拥有下面几种属性的: Method,Constructor,Field,其大致结构类图如下: 我们现在用代码来说明问题: 首先,我们看