一、通过反射创建运行时类对应的对象
@Test public void test1() throws IllegalAccessException, InstantiationException { Class<Person> clazz = Person.class; Person person = clazz.newInstance(); System.out.println(person); }
newInstance():调用此方法,获取对应的运行时类的对象,内部调用了运行时类的空参构造器。
要想此方法正常的创建运行时类的对象,要求:
- 运行时类必须提供空参的构造器
- 空参的构造器的访问权限得够,通常设置为public
拓展:在javabean中要求提供一个public的空参构造器的原因:
- 便于通过反射,创建运行时类的对象
- 便于子类继承此运行时类时,默认调用super()时,保证父类有此构造器。
如下代码体现反射的动态性这一重要特征:
@Test public void test2() throws Exception { //体会反射的动态性 for (int i = 0; i < 10; i++) { int math = new Random().nextInt(3); //math 为0,1,2 这三个随机数 String classPath = ""; switch (math){ case 0: classPath="www.demo8.Person"; break; case 1: classPath="java.lang.Object"; break; case 2: classPath="java.util.Date"; break; default: break; } try { Object obj = getInstance(classPath); System.out.println(obj); }catch (Exception e){ e.printStackTrace(); } } } /** * 创建一个指定类的对象 * classPath:指定类的全类名 * @param classPath * @return * @throws Exception */ public Object getInstance(String classPath) throws Exception { Class clazz = Class.forName(classPath); return clazz.newInstance(); }
结果是随机的:
java.lang.Object@1376c05c Mon Jul 12 21:17:55 CST 2021 java.lang.Object@1b4fb997 Mon Jul 12 21:17:55 CST 2021 Person{name='null', age=0} Mon Jul 12 21:17:55 CST 2021 Person{name='null', age=0} Mon Jul 12 21:17:55 CST 2021 Person{name='null', age=0} Mon Jul 12 21:17:55 CST 2021