方法局部内部类访问方法的局部变量


问题内容

嗨,我正在浏览有关内部类的SCJP书,发现了这一说法,类似这样。

方法本地类只能引用已标记的本地变量 final

在解释中,指定的原因与本地类对象和堆上的局部变量的范围和生存期有关,但我无法理解。我在这里想念任何东西final吗?


问题答案:

原因是,在创建方法本地类实例时,编译器实际上会将其引用的所有方法本地变量复制到其中。这就是为什么只能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,因此编译器可以将其“内联”到内部类中。