发现关于这个对内部类进行反射的问题网上很难找,现与大家分享一个例子。
import java.lang.reflect.Constructor;
import java.lang.reflect.Modifier;
public class ReflectInnerClass {
public static void main(String[] args){
}
public Runnable ta=new Runnable(){
public void run(){
System.out.println("匿名内部类中的方法被执行了");
}
};
private class Inner2{
public Inner2(){
System.out.println("private修饰Inner2类被实例化了");
}
}
static class Inner3{
public Inner3(){
System.out.println("静态Inner3类被实例化了");
}
}
public class Inner1{
public Inner1(){
System.out.println("public修饰Inner1类被实例化了");
}
}
}
class ReflectInnerClassTest {
public static void main(String args[]){
ReflectInnerClass ric=new ReflectInnerClass();
try {
reflectInnerClass(ric);
} catch (Exception e) {
e.printStackTrace();
}
}
private static void reflectInnerClass(ReflectInnerClass ric) throws Exception {
Class clazz=ric.getClass();
Class classes[]=clazz.getDeclaredClasses();
for(Class c:classes){//对成员内部类进行反射
int i=c.getModifiers(); //获取Java语言修饰符
String s=Modifier.toString(i);
if(s.contains("static"))//静态内部类的处理
c.getConstructor().newInstance();
else//实例内部类的处理
{
Constructor con=c.getConstructor(ric.getClass());
//System.out.println(con.getName());
con.newInstance(ric);
}
}
/*由于匿名内部类没有构建器,因此无法创建实例,也无法直接访问其中的方法,
但可以通过下面的方式巧秒的执行其中的方法或成员变量。 */
Runnable r=(Runnable)(clazz.getField("ta").get(ric));
r.run();
}
}
|