//考虑到从Java 程序到class 文件的映射的复杂度,请避免使用反射来实例化内部类。
//更一般地讲,当我们在用高级语言特性定义的程序元素之上使用反射的时候,一定要小心,
//从反射的视角观察程序可能不同与从代码的视角去观察它。
//一个非静态的嵌套类的构造器,在编译的时候会将一个隐藏的参数作为它的第一个参数,
//这个参数表示了它的直接外围实例(immediately enclosing instance)。
//当你在代码中任何可以让编译器找到合适的外围实例的地方去调用构造器的时候,这个参数就会被隐式地传递进去。
//但是,上述的过程只适用于普通的构造器调用,也就是不使用反射的情况。当你使用反射调用构造器时,
//这个隐藏的参数就需要被显式地传递,这对于Class.newInstance 方法是不可能做到的。
//要传递这个隐藏参数的唯一办法就是使用java.lang.reflect.Constructor。
class Outer {
void greetWorld() throws Exception {
//抛出异常
System.out.println( Inner.class.newInstance() );
}
void greetWorld1() throws Exception{
Constructor<Inner> c = Inner.class.getConstructor(Outer.class);
System.out.println(c.newInstance(Outer.this));
}
public class Inner {
public String toString(){
return "Hello world";
}
}
}