java性能优化--编译器版本与平台对应关系

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第20天,点击查看活动详情

在前一章节讲解了编译器的种类,以及验证各种编译器在不同情况下的性能表现,本章节更加具体化的学习编译器还有哪些可以优化的方便,让你的应用展现出更好的性能。

JIT编译器版本

JIT编译器有不同的版本,而最终你使用哪种,取决于你所使用的系统平台。前面的文章我们说到编译器有-client-server,具体划分应该是如下所示:

  • -client 32位client编译器
  • -server 32位server编译器
  • -d64 64位server编译器

如果你的系统是32位,那么你只能使用32位JVM,如果你是64位系统,那么可以选择32位或64位系统。

不同jvm的编译器版本如下:

jvm版本 -client -server -d64
linux 32位 32位client 32位server 出错
linux 64位 64位server 64位server 64位server
windows 32位 32位client 32位server 出错
windows 64位 64位server 64位server 64位server
macOS 64位server 64位server 64位server

我们使用的java8,默认使用的都是server编译器,同时是开启分层编译的。

默认情况JVM如何选择编译器?

假如我们没有指定编译器的参数,那么JVM是如何选择使用何种编译器的呢?

实际上jvm是考虑机器的CPU数目:

  • 在64位系统,无论机器多少CPU,都会使用server编译器

  • 在32系统

    • 如果只有一个cpu,那么使用client编译器
    • 多个cpu,使用server编译器。

如何判断当前环境jvm使用的编译器?

我们最经常使用的查看java版本命令,就可以在最后一行展示当前所使用的编译器类型:

[root@public-server9 esmp]# java -version
java version "1.8.0_172"
Java(TM) SE Runtime Environment (build 1.8.0_172-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.172-b11, mixed mode)
复制代码

如上所示,Linux环境下使用的是64位server编译器。

小节

不同的平台环境对应着不同的java版本,不同的java版本又对应着不同的编译器版本。我们在使用的时候,只需要选择对应于平台的java版本,不需要手动指定编译器,仰仗于平台所支持的编译器即可。

猜你喜欢

转载自juejin.im/post/7109633835805081636