翻译:吴嘉俊,叩丁狼高级讲师
关于逃逸分析
我在开源项目Speedment的开发过程中,我和项目的贡献者都意识到我们的代码不仅要良好并易懂,同时还要有较高的性能,否则他们很容易转向使用其他的解决方案。
逃逸分析(Escape Analysis)允许我们在写出性能较好的代码的同时,能通过恰当的抽象,保证良好的代码风格。
逃逸分析(简写为“EA”)允许java编译器在多种情况下优化我们的代码。请考虑一下代码:
public class Point {
private final int x, y;
public Point(int x, int y) {
this.x = x;
this.y = y;
}
@Override
public String toString() {
final StringBuilder sb = new StringBuilder()
.append("(")
.append(x)
.append(", ")
.append(y)
.append(")");
return sb.toString();
}
}
每一次我们调用Point::toString方法的时候,都会创建一个新的StringBuilder对象。这个创建出来的对象,对于外面的方法或者运行当前代码的其他线程都是不可见的(因为其他线程只能看到自己的StringBuilder版本)。
所以,当我们大量的调用了这个方法之后,会出现大量的StringBuilder对象么?不会。因为逃逸分析的作用,编译器会可以在栈上为StringBuilder分配空间。所以,当我们的方法返回的时候,对象会自动的被删除,栈上的指针会自动的回退到这个方法调用之前的值。
逃逸分析在Java中已经存在了很久了。在最开始的时候,我们需要在命令行选项中手动开启逃逸分析(通过-XX:+DoEscapeAnalysis开启),现在它已经作为默认开启的选项了。Java8在以前的Java基础上,对于逃逸分析&#