java反射实例

直接上原码

ReflectTester类

--------------------------------------------------------------------------------------------------

package com.fahon.mytest;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

public class ReflectTester {
public Object copy(Object object) throws Exception {
  // 获得对象的类型
  Class<?> classType = object.getClass();
  System.out.println("Class:" + classType.getName());

  // 通过默认构造方法创建一个新的对象,new Class[] {} 没参数表示用默认的构造方法
  Object objectCopy = classType.getConstructor(new Class[] {})
    .newInstance(new Object[] {});

  // 获得对象的所有属性,包括私有的
  Field fields[] = classType.getDeclaredFields();

  for (int i = 0; i < fields.length; i++) {
   Field field = fields[i];
   String fieldName = field.getName();
   String firstLetter = fieldName.substring(0, 1).toUpperCase();
   // 获得和属性对应的getXXX()方法的名字
   String getMethodName = "get" + firstLetter + fieldName.substring(1);
   // 获得和属性对应的setXXX()方法的名字
   String setMethodName = "set" + firstLetter + fieldName.substring(1);

   // 获得和属性对应的getXXX()方法 ,根据名字和参数取得对应的方法,getXXX()是没参数的,所以传个空的
   Method getMethod = classType.getMethod(getMethodName,
     new Class[] {});
   // 获得和属性对应的setXXX()方法,setXXX(Object obj),setXXX是有参数的,所以传当前字段的类型
   Method setMethod = classType.getMethod(setMethodName,
     new Class[] { field.getType() });

   // 调用原对象的getXXX()方法,调用getXXX()取得原对象的值
   Object value = getMethod.invoke(object, new Object[] {});
   System.out.println(fieldName + ":" + value);
   // 调用拷贝对象的setXXX()方法,调用新对象的setXXX()把值设置进去
   setMethod.invoke(objectCopy, new Object[] { value });
  }
  return objectCopy;
}

public static void main(String[] args) throws Exception {
  Customer customer = new Customer("Shmilyzl", 25);
  customer.setId(new Long(1));

  Customer customerCopy = (Customer) new ReflectTester().copy(customer);
  System.out.println("Copy information:" + customerCopy.getId() + " "
    + customerCopy.getName() + " " + customerCopy.getAge());
}
}
--------------------------------------------------------------------------------------------------

Customer类

--------------------------------------------------------------------------------------------------

package com.fahon.mytest;

class Customer {
private Long id;

private String name;

private int age;

public Customer() {
}

public Customer(String name, int age) {
  this.name = name;
  this.age = age;
}

public Long getId() {
  return id;
}

public void setId(Long id) {
  this.id = id;
}

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;
}
}

--------------------------------------------------------------------------------------------------

执行结果

--------------------------------------------------------------------------------------------------

Class:com.fahon.mytest.Customer
id:1
name:Shmilyzl
age:25
Copy information:1 Shmilyzl 25

--------------------------------------------------------------------------------------------------

注:源码来自网络,表原作者表示感谢!
Java反射机制允许你在运行时检查和操作程序的内部结构,包括加载类、创建实例、访问私有成员等。通过反射,即使在编译时未知的情况下,也可以动态地创建和操作对象。下面是使用Java反射进行实例化对象的基本步骤: 1. **获取Class对象**:首先,你需要找到你要实例化的类的Class对象。你可以通过类名或ClassLoader获取。 ```java Class<?> clazz = Class.forName("com.example.MyClass"); ``` 2. **创建实例(如果为静态工厂方法)**:如果类没有无参构造函数,可以通过`newInstance()`方法创建,但这个方法通常用于静态工厂方法。 ```java Object instance = clazz.newInstance(); ``` 3. **使用Constructor实例化**:如果需要使用特定构造函数,可以获取Constructor对象并调用其newInstance方法。 ```java Constructor<?> constructor = clazz.getDeclaredConstructor(String paramType); // 假设有个带String参数的构造函数 instance = constructor.newInstance("exampleValue"); ``` 4. **使用Reflective Constructor**:使用`ReflectiveConstructor`更强大,可以处理所有参数类型,即使在编译时无法确定。 ```java Constructor<?>[] constructors = clazz.getConstructors(); Constructor<?> constructor = constructors; // 选择一个 instance = constructor.newInstance(); ``` 5. **创建对象实例**:调用`newInstance()`或`Constructor`的实例化方法即可得到新创建的对象。 **相关问题--:** 1. Java反射的局限性是什么? 2. 如何判断一个类是否支持反射? 3. 什么时候会使用反射,而不是直接实例化?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值