JAVA反射实践
Java反射机制在我的理解当中就是下面几点:
1. 对一个给定的类名(以字符串形式提供)能动态构建一个对象实例
2. 对于任意一个类,都能够知道这个类的所有属性和方法
java.lang.Class;
java.lang.reflect.Constructor;
java.lang.reflect.Field;
java.lang.reflect.Method;
java.lang.reflect.Modifier;
public class Person {
// Field
private String person_name;
protected int person_age;
public boolean person_sex; // Construct
public Person() {
super();
} public Person(String name, int age, boolean sex) {
super();
this.setPerson_name(name);
this.person_age = age;
this.person_sex = sex;
} // Method
public void AddAge(int year) {
this.person_age += this.person_age + year;
} public String getPerson_name() {
return person_name;
} public void setPerson_name(String person_name) {
this.person_name = person_name;
}
}
public class Employee extends Person{
private double saray;
protected String gangwei; public Employee() {
super();
} public Employee(double saray, String gangwei) {
super();
this.saray = saray;
this.gangwei = gangwei;
} public double getSaray() {
return saray;
} public void setSaray(double saray) {
this.saray = saray;
} public String getGangwei() {
return gangwei;
} public void setGangwei(String gangwei) {
this.gangwei = gangwei;
} public void addSaray(double money){
this.saray+=money;
} }
1.根据类名构造一个实例
// 根据类名获取Class对象
Class c = Class.forName("Employee");
System.out.println(c.getName()); // 此处打印:Employee
// 获取父类Class对象
Class cp = c.getSuperclass();
System.out.println(cp.getName());// 此处打印:Person
// 获取类的访问修饰符
String modifiers = Modifier.toString(c.getModifiers());
System.out.println(modifiers); // 此处打印:public
// 实例化
Object obj = c.newInstance(); //通过无参的构造函数进行实例化
Class c = Class.forName("Employee");
- c.getField(name) ;
- c.getFields()
- c.getDeclaredFields()
- c.getDeclaredField(name)
<span style="white-space:pre"> </span>/*
* 获取类Employee的所有Field
*
* c.getField(name) c.getFields() c.getDeclaredFields()
* c.getDeclaredField(name)
*/
Field[] fields = c.getDeclaredFields();
for (Field f : fields) {
// 获取该Field的类型
Class type = f.getType();
// 获取该Field的名称
String name = f.getName();
// 获取该Field的访问修饰符
String sFieldModifiers = Modifier.toString(f.getModifiers());
System.out.println(sFieldModifiers + " " + type.getName() + " " + name + ";");
}
- * c.getDeclaredConstructors()
- * c.getConstructors()
- * c.getDeclaredConstructor(parameterTypes)
- * c.getDeclaredConstructor(parameterTypes)
<span style="white-space:pre"> </span>/*
* 获取类的构造函数
* c.getDeclaredConstructors()
* c.getConstructors()
* c.getDeclaredConstructor(parameterTypes)
* c.getDeclaredConstructor(parameterTypes)
*/
Constructor[] constructors = c.getDeclaredConstructors();
for (Constructor cr : constructors) {
// 构造函数名称
String name = cr.getName();
// 构造函数修饰符
String sConstructorModifiers = Modifier.toString(cr.getModifiers());
// 构造函数参数
Class[] paramTypes = cr.getParameterTypes();
String sParam = "";
for (int j = 0; j < paramTypes.length; j++) {
if (j > 0)
sParam += ", ";
sParam += paramTypes[j].getName();
}
System.out.println(sConstructorModifiers + " " + name + "(" + sParam + ");");
}
<span style="white-space:pre"> Method[] methods = c.getDeclaredMethods();
<span style="white-space:pre"> </span>for (Method m : methods) {
<span style="white-space:pre"> </span>// 方法返回类型
<span style="white-space:pre"> </span>Class returnType = m.getReturnType();
<span style="white-space:pre"> </span>String sReturnType = returnType.toString();
<span style="white-space:pre"> </span>// 方法名称
<span style="white-space:pre"> </span>String name = m.getName();
<span style="white-space:pre"> </span>// 方法修饰符
<span style="white-space:pre"> </span>String sMethodModifiers = Modifier.toString(m.getModifiers());
<span style="white-space:pre"> </span>// 方法参数
<span style="white-space:pre"> </span>Class[] paramTypes = m.getParameterTypes();
<span style="white-space:pre"> </span>String sParam = "";
<span style="white-space:pre"> </span>for (int j = 0; j < paramTypes.length; j++) {
<span style="white-space:pre"> </span>if (j > 0)
<span style="white-space:pre"> </span>sParam += ", ";
<span style="white-space:pre"> </span>sParam += paramTypes[j].getName();
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>System.out.println(sMethodModifiers + " " + sReturnType + " " + name + "(" + sParam + ");");
<span style="white-space:pre"> </span>}</span>
5.利用反射动态给对象属性赋值,比如我们需要从配置文件中读取某个员工的信息,并赋值给某个对象,我们可以这样写:
<span style="white-space:pre"> </span>/*
<span style="white-space:pre"> </span> * 动态给类的属性赋值
<span style="white-space:pre"> </span> */
<span style="white-space:pre"> </span>Class c2 = Class.forName("Employee");
<span style="white-space:pre"> </span>Object e = c2.newInstance();
<span style="white-space:pre"> </span>Field f = c2.getDeclaredField("saray");
<span style="white-space:pre"> </span>// 因为属性saray是private的,所有需要调用setAccessible方法才能给该属性赋值,否则报错
<span style="white-space:pre"> </span>f.setAccessible(true);
<span style="white-space:pre"> </span>f.set(e, 10000);
<span style="white-space:pre"> </span>Field f2 = c2.getDeclaredField("gangwei");
<span style="white-space:pre"> </span>f2.set(e, "高级软件工程师");
<span style="white-space:pre"> </span>System.out.println(((Employee) e).getGangwei() + " " + ((Employee) e).getSaray());
<span style="white-space:pre"> </span>// 取值
<span style="white-space:pre"> </span>Field f3 = c2.getDeclaredField("saray");
<span style="white-space:pre"> </span>Field f4 = c2.getDeclaredField("gangwei");
<span style="white-space:pre"> </span>f3.setAccessible(true);
<span style="white-space:pre"> </span>System.out.println(f3.get(e));
<span style="white-space:pre"> </span>System.out.println(f4.get(e));
高级软件工程师 10000.010000.0高级软件工程师
Class c3 = Class.forName("Employee");
Object e3 = c3.newInstance();
Field fSaray = c3.getDeclaredField("saray");
fSaray.setAccessible(true);
fSaray.set(e3, 10000);
System.out.println(fSaray.get(e3)); //输出10000
// 获取Method
Method m = c3.getDeclaredMethod("addSaray", double.class);
/*
* Method m = c3.getDeclaredMethod("addSaray"); Method m2 =
* c3.getDeclaredMethod("addSaray", double.class);
* 如果有多个重名的方法,要添加参数让编译器知道应该调用哪个方法,这里只有一个参数,所以上面两种写法都可以
*/
// 调用方法
m.invoke(e3, 5000);
System.out.println(fSaray.get(e3)); //输出15000,因此证明方法调用成功
输出结果如下:
10000.015000.0
JAVA反射实践的更多相关文章
- java 反射实践
/** * * @author yuxg */ import coreJava.javaFile; import javaClassStudy.Student; import javaClassStu ...
- java反射基础知识(五)反射应用实践
详解Java反射各种应用 Java除了给我们提供在编译期得到类的各种信息之外,还通过反射让我们可以在运行期间得到类的各种信息.通过反射获取类的信息,得到类的信息之后,就可以获取以下相关内容: Cl ...
- java反射-- Field 用法实践
java 反射是一种常用的技术手段, 通过加载类的字节码的方式来获取相关类的一些信息 比如成员变量, 成员方法等. Field 是什么呢? field 是一个类, 位于java.lang.reflec ...
- Java反射(六)纯面向接口编程的简单框架实践
我们知道在使用MyBatis开发时,只需要添加DAO接口和对应的映射XML文件,不需要写DAO的实现类,其实底层是通过动态代理实现. 本文将使用前几篇文章的知识点实现一个纯面向接口编程的简单框架,与M ...
- 大型网站系统与Java中间件实践
大型网站系统与Java中间件实践(贯通分布式高并发高数据高访问量网站架构与实现之权威著作,九大一线互联网公司CTO联合推荐) 曾宪杰 著 ISBN 978-7-121-22761-5 2014年4 ...
- java 反射(reflect)总结,附对象打印工具类
java反射机制认知 java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取类的信息以及动态调用对象的方法的 ...
- Java 反射机制详解
动态语言 动态语言,是指程序在运行时可以改变其结构:新的函数可以被引进,已有的函数可以被删除等在结构上的变化.比如众所周知的ECMAScript(JavaScript)便是一个动态语言.除此之外如Ru ...
- 一个例子让你了解Java反射机制
本文来自:blog.csdn.net/ljphhj JAVA反射机制: 通俗地说,反射机制就是可以把一个类,类的成员(函数,属性),当成一个对象来操作,希望读者能理解,也就是说,类,类的成员,我们在运 ...
- (转)个例子让你了解Java反射机制
个例子让你了解Java反射机制 原文地址:http://blog.csdn.net/ljphhj/article/details/12858767 JAVA反射机制: 通俗地说,反射机制就是可 ...
随机推荐
- mongodb高级查询
前几篇,老玩家绕道即可,新手晚上闲着也是蛋疼,不如把命令敲一边,这样你就会对MongoDB有一定的掌握啦.如果没有安装MongoDB去看我的上一篇博客 MongoDB下载安装与简单增删改查 前奏:启 ...
- linux c 获取头文件函数getenv
#include <stdio.h>#include <stdlib.h> int main(){ printf("%s\n", getenv(" ...
- maven 手动安装本地jar包(转载)
From:http://www.cnblogs.com/leiOOlei/p/3356834.html 安装命令: -Dpackaging=jar
- 使用Junit对Spring进行单元测试实战小结
Demo代码: @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath*:/ ...
- CuteSTL——跟着感觉造轮子
置顶推荐: CuteSTL:https://github.com/jxd134/algorithm/tree/master/CuteSTL TinySTL:https://github.com/zou ...
- 在ANSYS WORKBENCH中使用APDL命令的例子
如何在workbench中使用command? 如何在ansys workbench中插入apdl? 如何在ansys workbench中使用复杂载荷? 答案在APDL,他可以实现函数化的载荷,如岁 ...
- VMware Workstation 11, 客户机Ubuntu14.04.1 LTS 64bit,宿主机Windows 8.1 64bit,剪贴板共享(copy and paste)失效问题
Ubuntu14.04是从12.04升级上来的,因为GUI性能的原因相继装了Xubunbu和Lubuntu的包(Lubuntu的桌面果然轻量级,但是请神容易送神难,卸载Xubuntu很麻烦,就先放下了 ...
- http://paulgraham.com/arcfaq.html
Why not use some other delimiter than parentheses?为什么不使用一些其他的分隔符比括号?We tried various possibilities. ...
- 一个input标签搞定含内外描边及阴影的按钮~
自从怀孕以来,我就变得很是轻松,偶尔写一两个页面,或者偶尔调试一个两个bug,或者偶尔给做JS的同事打打下手,修改个bug什么......一个习惯于忙碌的工作的人,这一闲下来,感觉还真TM很不舒服-怎 ...
- 【Python】Celery异步处理
参考:http://www.cnblogs.com/znicy/p/5626040.html 参考:http://www.weiguda.com/blog/73/ 参考:http://blog.csd ...