Class<?> clazz = Class.forName(“全类名”);
clazz.newInstance();//利用空参构造,返回该类对象,通过字节码对象创建实例对象
1.获取构造方法对象
Constructor c = clazz.getConstructor(Class...arg),获取某个构造方法的对象,再用c.newInstance(Object...arg);
如:Constructor c = clazz.getConstructor(String.class,int.class)
Person p = c.newInstance("张三",20);
2.获取成员变量
Field f = clazz.getDeclaedField("name");//暴力反射,私有的也可以获取。
f.setAccessible(true);设置权限,变得不私有。
f.set(p,"李四");//将p对象的name变量的值改为"李四";
3.获取成员方法
Method m = clazz.getDeclaredMethod("eat",int.class);//前一个参数是方法名,后一个参数时方法中的参数类型的字节码类型
m.invoke(p,10);//调用p对象的eat方法,传入int类型的参数值为10;
* 接口中可以定义有方法体的方法,如果是非静态,必须用default修饰
* 如果是静态的就不用了
class Test {
public void run() {
final int x = 10;
class Inner {
public void method() {
System.out.println(x);
}
}
Inner i = new Inner();
i.method();
}
}
局部内部类在访问他所在方法中的局部变量必须用final修饰,为什么?
因为当调用这个方法时,局部变量如果没有用final修饰,他的生命周期和方法的生命周期是一样的,当方法弹栈,这个局部变量也会消失,那么如果局部内部类对象还没有马上消失想用这个局部变量,就没有了,如果用final修饰会在类加载的时候进入常量池,即使方法弹栈,常量池的常量还在,也可以继续使用