JVM的逃逸分析

HotSpot中内置了两个即时编译器,分别称为 Client Compiler和 Server Compiler ,或者简称为 C1 编译器和 C2 编译器。目前的 HotSpot 编译器默认的是解释器和其中一个即时编译器配合的方式工作,具体是哪一个编译器,取决于虚拟机运行的模式,HotSpot 虚拟机会根据自身版本与计算机的硬件性能自动选择运行模式,用户也可以使用 -client 和 -server 参数强制指定虚拟机运行在 Client 模式或者 Server 模式。这种配合使用的方式称为“混合模式”(Mixed Mode),用户可以使用参数 -Xint 强制虚拟机运行于 “解释模式”(Interpreted Mode),这时候编译器完全不介入工作。另外,使用 -Xcomp 强制虚拟机运行于 “编译模式”(Compiled Mode),这时候将优先采用编译方式执行,但是解释器仍然要在编译无法进行的情况下接入执行过程。通过虚拟机 -version 命令可以查看当前默认的运行模式。

栈上分配

我们都知道,JVM的一切对象都是在堆上分配(当然还有String这种对象分配到方法区的)。不过这么整洁美丽的规律显然不符合毫无美感的java程序员。所以,JVM引入了逃逸分析。大概意思就是说,如果你可以证明一个方法中新建的对象只在方法中引用,而不会作为参数调用被传递到其他方法的执行中,就可以进行一些优化,比如说在栈上直接分配内存。

同步消除

如果你定义的类的方法上有同步锁,但在运行时,却只有一个线程在访问,此时逃逸分析后的机器码,会去掉同步锁运行。

标量替换

参考问题

http://www.importnew.com/23150.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM 逃逸分析(Escape Analysis)是一种用于分析 Java 代码中对象的作用域的技术。它可以帮助 JVM 在运行时确定对象的作用域,从而优化代码的性能。 在 Java 中,对象的生命周期是由它的作用域决定的。如果一个对象在方法内部创建并且只在该方法中使用,那么它的作用域就被限制在了该方法内部。这种对象被称为局部对象(Local Object)。如果一个对象在方法内部创建但是在方法外部被引用,那么它的作用域就被扩展到了方法外部。这种对象被称为逃逸对象(Escape Object)。 JVM 逃逸分析就是用来分析对象的作用域的。通过对代码的分析,JVM 可以确定哪些对象是局部对象,哪些对象是逃逸对象。对于局部对象,JVM 可以在栈上分配内存,这样可以避免在堆上分配内存的开销,从而提高代码的性能。对于逃逸对象,JVM 则必须在堆上分配内存。 JVM 逃逸分析对于代码性能的影响非常大。如果一个方法中大量使用逃逸对象,那么 JVM 将不得不频繁地在堆上分配内存,这将影响代码的性能。但是如果一个方法中大量使用局部对象,那么 JVM 可以将这些对象分配到栈上,从而避免在堆上分配内存的开销,这将大大提高代码的性能。 总之,JVM 逃逸分析是一种非常重要的技术,它可以帮助 JVM 在运行时优化代码的性能,提高代码的执行效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值