反射机制--获取实例化对象

在上一节中(点击打开链接),获取到了字节码文件对象,那么如何获取该字节码文件对应的Person对象呢?(仍然使用在text包下定义的Person类。)

运行早期的方法:

package text;

public class ReflectDemo2 {

	public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
		creatNewObject_1();
	}

	public static void creatNewObject_1() throws ClassNotFoundException, InstantiationException, IllegalAccessException{
		//早期:new的时候,先根据被new的类的名称找寻该类的字节码文件,并加载进内存,并创建该字节码文件对象,并接着创建该字节码文件对应的Person对象。
		text.Person p=new text.Person();
		
		//现在
//		String  name="text.Person";
//		Class clazz = Class.forName(name);  //找寻该名称类文件,并加载进内存,并产生Class对象
//		Object obj = clazz.newInstance(); //产生该类的对象,newInstance()创建此Class对象所表示的类的一个新实例
	}
}

运行结果:



运行现在的方法:

package text;

public class ReflectDemo2 {

	public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
		creatNewObject_1();
	}

	public static void creatNewObject_1() throws ClassNotFoundException, InstantiationException, IllegalAccessException{
		//早期:new的时候,先根据被new的类的名称找寻该类的字节码文件,并加载进内存,并创建该字节码文件对象,并接着创建该字节码文件对应的Person对象。
//		text.Person p=new text.Person();
		
		//现在
		String  name="text.Person";
		Class clazz = Class.forName(name);  //找寻该名称类文件,并加载进内存,并产生Class对象
		Object obj = clazz.newInstance(); //产生该类的对象,newInstance()创建此Class对象所表示的类的一个新实例
	}
}
运行结果:


在creatNewObject_1()方法中使用的创建对象都是无参的构造函数,我们通过creatNewObject_2()有参的构造函数来创建对象:

运行早期方法:

package text;

import java.lang.reflect.Constructor;

public class ReflectDemo2 {

	public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
		creatNewObject_2();
	}

	public static void 	creatNewObject_2(){
		//早期
		text.Person p=new text.Person(39,"小强");
		
		//现在
		/*
		 * 当要获取指定名称对应的类中所体现的对象时,而该对象初始化不使用空参数构造函数时:
		 * 既然是通过指定的构造函数进行对象的初始化,应该先获取到该指定的构造函数。通过字节码文件对象即可完成,
		 * 该方法是getConstructors(paramterTypes),返回一个Constructor对象,反映此Class对象表示的所有公共构造方法。
		 * */
//		String  name="text.Person";
//		Class clazz = Class.forName(name);
//		//获取到了指定的构造函数对象
//		Constructor constructor=clazz.getConstructor(int.class,String.class);
//		
//		//通过该构造器对象的newInstance方法进行对象的初始化
//		Object obj=constructor.newInstance(38,"小明");
	}
	
}
运行结果:


运行现在方法:

package text;

import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;

public class ReflectDemo2 {

	public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException, NoSuchMethodException, SecurityException, IllegalArgumentException, InvocationTargetException {
		creatNewObject_2();
	}

	public static void 	creatNewObject_2() throws ClassNotFoundException, NoSuchMethodException, SecurityException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{
		//早期
//		text.Person p=new text.Person(39,"小强");
		
		//现在
		/*
		 * 当要获取指定名称对应的类中所体现的对象时,而该对象初始化不使用空参数构造函数时:
		 * 既然是通过指定的构造函数进行对象的初始化,应该先获取到该指定的构造函数。通过字节码文件对象即可完成,
		 * 该方法是getConstructors(paramterTypes),返回一个Constructor对象,反映此Class对象表示的所有公共构造方法。
		 * */
		String  name="text.Person";
		Class clazz = Class.forName(name);
		//获取到了指定的构造函数对象
		Constructor constructor=clazz.getConstructor(int.class,String.class);
		
		//通过该构造器对象的newInstance方法进行对象的初始化
		Object obj=constructor.newInstance(38,"小明");
	}
	
}
运行结果:




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`.class` 和反射机制都可以用于创建对象的实例,但它们的实现方式和使用场景有所不同。 1. `.class`:通过 `.class` 获取一个类的 Class 对象,可以使用 `new` 关键字直接实例化该类的对象。例如,`MyClass obj = new MyClass();`。这种方式是在编译时确定类型并直接创建对象。`.class` 文件必须在编译时存在,否则无法进行实例化。 2. 反射机制:通过反射机制,可以在运行时动态地获取类的信息,并且可以通过 Class 对象的相关方法实例化对象。例如,`Class.forName("com.example.MyClass").newInstance();`。这种方式是在运行时根据类名动态加载并创建对象。通过反射,可以实例化任意一个已经被加载到内存中的类,甚至是在编译时无法确定的类型。 区别: - `.class` 方式在编译时就确定了具体的类型,直接使用 `new` 关键字创建对象,比较简单直观。 - 反射机制通过运行时动态获取类的信息,并且可以实例化任意已加载的类,具有更大的灵活性和扩展性。但相对于直接使用 `.class` 方式,反射机制的性能较低,因为需要动态地加载和实例化对象。 需要根据具体的需求来选择使用哪种方式来实例化对象。如果在编译时已经确定了具体的类型,可以直接使用 `.class` 方式来创建对象。如果需要在运行时动态加载和创建对象,或者需要处理一些动态生成的类,可以使用反射机制实例化对象

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值