Java中的反射

java的反射原理:

 

测试类:

package com.jlee.test;

public class MyBean {

	private Integer id ;
	private String name ;
	private Long amount ;
	private boolean isRight ;
	private double num ;
	
	private static String clazzProperty ;
	
	public static String getClazzProperty() {
		return clazzProperty;
	}
	public static void setClazzProperty(String clazzProperty) {
		MyBean.clazzProperty = clazzProperty;
	}

	private MyTest myTest ;
	
	public MyTest getMyTest() {
		return myTest;
	}
	public void setMyTest(MyTest myTest) {
		this.myTest = myTest;
	}
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Long getAmount() {
		return amount;
	}
	public void setAmount(Long amount) {
		this.amount = amount;
	}
	public boolean getIsRight() {
		return isRight;
	}
	public void setIsRight(boolean isRight) {
		this.isRight = isRight;
	}
	public double getNum() {
		return num;
	}
	public void setNum(double num) {
		this.num = num;
	}
	
	public static String staticMethod(String arg){
		return "执行类方法......." + arg;
	}
	
	@Override
	public String toString() {
		return "bean的值   id:"+this.getId()+"   name:"+this.getName()
				+"   num:"+this.getNum()+"  amount:"+this.getAmount() 
				+ "  isRight:" + this.getIsRight()+"  类属性:"+this.getClazzProperty();
	}
	
}

 

 

反射实现类:

package com.jlee.test;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import com.jlee.test.MyBean;
/**
 * 
 * @author JLee
 * @Date 2010-3-2
 */
public class TestReflaction {

	public static void main(String[] args)throws Exception {
		MyBean bean = new MyBean();
		
		bean.setAmount(Long.parseLong("123123"));
		bean.setId(2);
		bean.setIsRight(false);
		bean.setName("jlee01");
		bean.setNum(1);
		System.out.println("修改前:"+bean.toString());
		
		TestReflaction t = new TestReflaction();
		t.mf1(bean, "name", "jlee02");
		t.mf1(bean, "num", 2) ;
		System.out.println("第一次修改:"+bean.toString());
		
		
		t.mf2("com.jlee.test.MyBean", "clazzProperty", "static");
		System.out.println("第二次修改:"+bean.toString());
		
		Class[] argTypes = new Class[]{String.class};
		Object[] args1 = new Object[]{"jlee03"};
		t.mf3(bean, "setName", argTypes, args1);
		System.out.println("第三次修改:"+bean.toString());
		
		String str = t.mf4("com.jlee.test.MyBean", "staticMethod", new Class[]{String.class}, new Object[]{"结束"});
		System.out.println(str);
	}
	
	
	//直接操作对象属性
	public void mf1(Object o , String fieldName ,Object newValue)throws Exception {
		Class c = o.getClass() ;
		Field f = c.getDeclaredField(fieldName);
		f.setAccessible(true);   
		f.set(o, newValue);
	}
	
	//直接操作类(Static)属性
	public void mf2(String className, String fieldName ,Object newValue)throws Exception {
		Class c = Class.forName(className) ;
		Field f = c.getDeclaredField(fieldName);
		f.setAccessible(true);   
		Object fv = f.get(c);
		f.set(c, newValue);
	}
	
	//调用对象成员方法
	public void mf3(Object o,String methodName,Class[] argTypes,Object[] args)throws Exception{
		Class c = o.getClass() ;
		Method m = c.getDeclaredMethod(methodName, argTypes);
		Object result = m.invoke(o, args);
	}
	
	//调用类成员方法(static的方法)
	public String mf4(String className,String methodName,Class[] argTypes,Object[] args)throws Exception{
		Class c = Class.forName(className);
		Method m = c.getDeclaredMethod(methodName, argTypes);
		Object result = m.invoke(null, args);
		return result.toString() ;
	}
}

 

### 三级标题:Java反射的定义与工作原理 Java中的反射机制是一种允许程序在运行时动态地检查和操作类、接口、字段、方法等内部信息的技术。通过这种机制,可以在不知道对象具体类型的情况下创建对象、调用方法以及访问其属性,甚至包括私有成员。这一特性赋予了Java程序极大的灵活性和扩展性,是构建复杂系统时不可或缺的一部分[^1]。 当一个类被加载到JVM(Java虚拟机)中后,每个类都会对应生成一个`Class`对象。这个`Class`对象包含了该类的所有信息,如构造函数、方法列表、属性等。正常情况下,我们使用类来创建实例;而在反射机制下,则可以通过获取到的`Class`对象来反向了解并操作对应的类及其对象。这意味着开发者能够在应用程序执行期间对类的行为进行修改或增强,例如读取文件内容存入Bean再存储至数据库的过程中遇到字段名不匹配的问题时,可以利用反射动态处理不同命名规则之间的映射关系[^4]。 实现反射功能的核心在于`java.lang.reflect`包提供的APIs,它支持动态地加载类、获取类的信息、创建实例及调用方法等功能。比如,若想通过反射调用某个方法,首先需要获得目标类的`Class`对象,然后查找所需的方法,并设置访问权限(对于私有方法),最后才能完成实际的调用过程。下面是一个简单的示例展示了如何使用反射来调用一个方法: ```java public class ReflectionExample { public void sayHello() { System.out.println("Hello from reflection!"); } public static void main(String[] args) throws Exception { // 获取ReflectionExample类的Class对象 Class<?> clazz = Class.forName("ReflectionExample"); // 创建实例 Object instance = clazz.getDeclaredConstructor().newInstance(); // 获取sayHello方法 Method method = clazz.getMethod("sayHello"); // 调用方法 method.invoke(instance); } } ``` 上述代码演示了从加载类到最终调用其公共方法的基本流程。值得注意的是,在涉及私有成员时还需额外调用`setAccessible(true)`以绕过Java语言的安全限制。 综上所述,Java反射机制基于每个类唯一的`Class`对象,使得程序具备了在运行时刻分析类的能力,从而实现了高度灵活的应用开发模式。然而,尽管反射提供了强大的功能,但过度依赖可能会导致性能下降以及安全风险增加等问题,因此应当谨慎使用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值