原因是,在创建方法本地类实例时,编译器实际上会将其引用的所有方法本地变量复制到其中。这就是为什么只能
final访问变量的原因。甲
final变量或参考是不变的,所以它停留在同步与其方法本地对象内副本。如果不是这样,则可以在创建方法本地类后更改原始值/引用,从而让行为和细微的错误产生混乱。
考虑一下JavaSpecialist时事通讯No.的示例。25:
public class Access1 { public void f() { final int i = 3; Runnable runnable = new Runnable() { public void run() { System.out.println(i); } }; }}编译器将内部类转换为:
class Access1$1 implements Runnable { Access1$1(Access1 access1) { this$0 = access1; } public void run() { System.out.println(3); } private final Access1 this$0;}由于的值
i是final,因此编译器可以将其“内联”到内部类中。



