反射实例化内部类

内部类的初始化同一般类的初始化基本相同,只是内部类的类名全称有些区别。下面定义了一个Outer类和一个Inner类:

public class Outer{
public class Inner{
}
}

通过如下方法可以得到Inner类的类名:

public class Outer{
public class Inner{
}
public static void main(String[] args){
System.out.println(Inner.class);
}
}


从输出结果可以看到,Inner的类名是xxx.xxx.Outer$Inner这种形式的。这是Java中所谓的synthetic
name。也就是这个名字在源代码中是找不到对应的文件的,是编译器经过修饰之后的名字。

反射实例化内部类的代码如下:

import java.lang.reflect.*;
public class Outer{
public class Inner{
}
public static void main(String[] args) throws InstantiationException,
IllegalAccessException,InvocationTargetException{
System.out.println(Inner.class);
//查看class是否有构造函数
System.out.println(Inner.class.getConstructors().length);
//获取第一个构造函数
System.out.println(Inner.class.getConstructors()[0]);
//用构造函数初始化内部类
System.out.println(Inner.class.getConstructors()[0].newInstance(new Outer()));
}
}



从上面代码的打印输出可以看到,公开非静态内部类的默认构造函数需要一个外围类的实例。
如果是public static的内部类,则默认构造函数是一个无参的构造函数。如果把Inner类的public关键字去掉,运行上面代码会发现抛错了,因为找不到 Inner的构造函数。这个时候只需要将getConstructors方法换成getDeclaredConstructors就可以了。
如果内部类是私有的,在初始化的时候要将构造函数的访问设置成true。如下:

import java.lang.reflect.*;
public class Outer{
private class Inner{
}
public static void main(String[] args) throws InstantiationException,
IllegalAccessException,InvocationTargetException{
System.out.println(Inner.class);
//查看class是否有构造函数
System.out.println(Inner.class.getDeclaredConstructors().length);
//获取第一个构造函数
Constructor c = Inner.class.getDeclaredConstructors()[0];
//将c设置成可访问
c.setAccessible(true);
//用构造函数初始化内部类
System.out.println(c.newInstance(new Outer()));
}
}


原文出去:[url]http://www.java3z.com/cwbwebhome/article/article8/857.html[/url]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值