Tag*_*eev 11 java javac java-8
最近我发现了匿名类和lambda表达式之间的细微差别:
public class FinalTest {
final Runnable x = new Runnable() {
@Override
public void run() {
System.out.println(x.hashCode());
}
};
final Runnable y = () -> System.out.println(y.hashCode());
}
Run Code Online (Sandbox Code Playgroud)
通常lambdas等同于匿名类.甚至我的Eclipse IDE都有重构转换x为lambda(它变得完全像y)并转换y为匿名类(它变得完全一样x).然而lambda给了我一个编译错误,而匿名类可以完美编译.错误消息如下所示:
>javac FinalTest.java
FinalTest.java:9: error: self-reference in initializer
final Runnable y = () -> System.out.println(y.hashCode());
^
1 error
Run Code Online (Sandbox Code Playgroud)
所以问题是:为什么会有这样的差异?
ass*_*ias 15
这与处理前向引用的JLS#8.3.3有关.特别是,如果使用完全限定名称,则编译它(因为该规则的第三个条件变为false)在C的实例变量初始值设定项或C的实例初始值设定项中使用是简单名称:
final Runnable y = () -> System.out.println(this.y.hashCode());
Run Code Online (Sandbox Code Playgroud)
在匿名类的情况下,第四个条件(C是最内层的类或包含使用的接口)不正确,因为封闭类本身就是匿名类.
| 归档时间: |
|
| 查看次数: |
423 次 |
| 最近记录: |