jvm|JVM底层原理之如何选用C1、C2编译器?它们有什么区别?

jvm|JVM底层原理之如何选用C1、C2编译器?它们有什么区别?

文章图片


JVM底层原理之如何选用C1、C2编译器?它们有什么区别?
关于JVM底层的C1、C2编译器 , 很多人不知道它的具体概念 , 本篇我们详细的讲解一下 。
什么是C1?什么是C2?开发人员可以通过设置 , 控制虚拟机采用解释执行的方式或者是采用即时编译器的方式 , 配置如下:

  • -Xint 采用解释器模式执行
  • -Xcomp 采用即使编译器模式执行
  • -Xmixed 采用解释器+即使编译器的混合模式共同执行
hotspot虚拟机内嵌有两个JIT编译器 , 分别是Client Compiler 和Server Compiler , 不过大多数情况下简称为C1和C2编译器
client模式是一种轻量级编译器 , 也叫C1编译器 , 占用内存小 , 启动快 , 耗时短 , 它会进行简单并可靠的优化 , 更注重效率 。
server模式是一种重量级编译器 , 也叫C2编译器 , 启动慢 , 占用内存大 , 耗时长 , 但编译的代码执行效率更高 , 甚至会根据性能监控信息进行一些不可靠的激进优化 , 更注重质量 。
JDK7以前选用C1或C2编译器①自动选择通常虚拟机会根据机器的硬件和操作系统自动选择运行C1还是C2 , 详情可以参考官方提供的手册:

②手动选择我们在启动程序的时候也可以通过手动去控制运行模式:
混合模式(Mixed Mode):使用解释器 + 其中一个JIT编译器 , 指令【-client】或【-server】 指定使用哪个JIT编译器 。 不加任何指令 , 默认启动也是此模式 。 解释模式(Interpreted Mode):只使用解释器 , 禁用JIT , 指令【-Xint】强制JVM使用解释模式 。 编译模式(Compiled Mode):只使用编译器 , 指令【-Xcomp】 优先使用编译模式将所有字节码编译成本地机器码 , 解释模式作为备用 。
相信有人注意到了标题 , 为什么特别的说是JDK7以前呢?难道JDK7以后就不用选了吗?
【jvm|JVM底层原理之如何选用C1、C2编译器?它们有什么区别?】没错 , 从JDK7开始 , Java引入了分层编译 , 关于分层编译的原理 , 我们在下篇继续讲解 。 想了解的小伙伴可以关注我 , 或从我的主页点进去查看哦~