考虑以下代码片段:
public static Object o = new Object();
public static Callable x1() {
Object x = o;
return () -> x;
}
public static Callable x2() {
return () -> o;
}
方法x2()
将始终返回相同的lamba对象,而x1()
将始终创建新的对象:
System.out.println(x1());
System.out.println(x1());
System.out.println(x2());
System.out.println(x2());
将打印出类似下面这样的内容:
TestLambda$$Lambda$1/821270929@4a574795
TestLambda$$Lambda$1/821270929@f6f4d33
TestLambda$$Lambda$2/603742814@7adf9f5f
TestLambda$$Lambda$2/603742814@7adf9f5f
在哪里(我猜是在JVM规范中?)是否描述了lambda重用的规则?JVM如何决定在哪里重用?
发布于 2015-04-17 01:37:59
编译器没有办法优化x1()
以返回相同的lambda --这样行为就会不同。因为o
不是最终的,所以返回的lambda需要捕获该字段的状态(使用x
变量),因为它的值可能在调用x1()
和调用返回的lambda之间发生变化。
这并不是说,在理论上编译器可以重用实例,但不能重用实例的情况(其他答案对此有一些见解) --只是说这不是那种情况。
https://stackoverflow.com/questions/29674645
复制相似问题