作者 | 小灰

来源 | 程序员小灰(ID:chengxuyuanxiaohui)

中央处理器,即CPU,包含很多种设计架构。其中最常见的架构有两种,一种是X86架构,一种是ARM架构。

这两种架构有什么不同呢?主要是使用的指令集不一样。

X86架构使用CISC指令集,即复杂指令集,最典型的代表就是英特尔处理器。

ARM架构使用RISC指令集,即精简指令集,华为的鲲鹏就是基于ARM架构。

OpenJDK,对于X86架构处理器有很好的支持,虽然也基本支持ARM架构处理器,但是在性能上并不理想。

正是为了弥补OpenJDK在ARM架构上运行的劣势,华为开源了自己研发的JDK发行版,并贡献到openEuler 开源社区,这就是咱们提到的Bisheng JDK。

优化1:增加AppCDS的支持

AppCDS,是Java当中的一个新特性,全称是Application Class-Data Sharing。

要解释这个特性,就不得不先讲解一下Java的类加载过程。

众所周知,JVM会把你写的每一行Java代码都编译成字节码,存储在class文件当中。在运行时,JVM会加载这些class文件,并解释执行。

Java的默认类加载器有三种,层次从高到低,分别是BootstrapClassLoader,ExtClassLoader,AppClassLoader。

启动JVM的时候,进行类加载工作会占用一定的时间。

如果我们同时运行多个Java进程,也就是启动了多个JVM,每一个JVM都重复加载许多相同的字节码,会浪费许多无谓的时间:

如果我们能在JVM第一次成功加载这些class之后,把class的信息归档到一个共享空间中,让其他的JVM也能直接获取到这些加载完成的class信息,岂不是节省了很多时间?

早在JDK1.5版本,Java团队就给出了类似的解决方案,这个特性叫做CDS(Class-Data Sharing)。

可惜的是,CDS这个特性只局限于BootstrapClassLoader层级的class-data共享,虽然也带来了一定的性能优化,但是杯水车薪。

后来,Java团队把class-data共享的范围扩展到了AppClassLoader这个层级,这就是所谓的AppCDS。

AppCDS为JVM的类加载带来了明显的性能优化,但仍然有一点美中不足:AppCDS是Oracle JDK8的收费商用特性,在OpenJDK8当中并不支持。

幸好Bisheng JDK团队解决了这个问题,使得鲲鹏上面运行的Java代码也能享受到AppCDS带来的性能优化。

目前,该优化针对的版本是Bisheng JDK 8。

优化2:增加ZGC的支持

GC,即垃圾回收机制,做过Java的小伙伴恐怕没有人不知道。

JVM垃圾回收,面临的最大痛点是什么呢?毫无疑问,是回收过程中用户线程的停顿。

为了解决这个痛点,尽量缩短停顿时间,Java团队做了很多的努力,各种各样的垃圾回收器随之诞生,比如Serial,Parallel,CMS,G1......

在JDK11中,又一种全新的垃圾回收器诞生了,这种垃圾回收器叫做ZGC。

ZGC满足了如下三大目标:

停顿时间控制在10ms之内

停顿时间不会因为堆变大而变长

堆大小支持TB级

尽管ZGC在对象回收的吞吐量方面略逊于G1回收器(差距小于15%),但综合来讲,ZGC已经是目前足够好用的垃圾回收器了。

可令人遗憾的是,ZGC这么好的垃圾回收器,暂时并不支持ARM架构处理器。(ZGC处于实验阶段)

为此,Bisheng JDK团队对OpenJDK进行了扩展,使得ARM架构处理器也能享受到ZGC带来的垃圾回收优化。

目前,该优化针对的版本是Bisheng JDK 11。

Bishengjdk8:

https://gitee.com/openeuler/bishengjdk-8

Bishengjdk11:

https://gitee.com/openeuler/bishengjdk-11

更多精彩推荐
☞太扎心!人艰不拆!16 个程序员专属笑话讲给你听
☞抗住 8 亿人买买买!双 11 背后黑科技大曝光
☞中国联通最快明年实现2G全面退网;苹果发布iOS 14.3后火速撤回:原因未知;Angular 11.0.0 正式发布|极客头条
☞强化学习:10种真实的奖励与惩罚应用
☞打钱!我的数据库被黑客勒索了!
☞对区块链撒谎:将“垃圾进,垃圾出”问题应用在去中心化网络上
点分享点点赞点在看

漫画:毕昇 JDK,重现了 “活字印刷术” 的传奇相关推荐

  1. 毕昇JDK,重现了 “活字印刷术” 的传奇

    中央处理器,即CPU,包含很多种设计架构.其中最常见的架构有两种,一种是X86架构,一种是ARM架构. 这两种架构有什么不同呢?主要是使用的指令集不一样. X86架构使用CISC指令集,即复杂指令集, ...

  2. jdk支持arm_毕昇JDK,重现了 “活字印刷术” 的传奇

    中央处理器,即CPU,包含很多种设计架构.其中最常见的架构有两种,一种是X86架构,一种是ARM架构. 这两种架构有什么不同呢?主要是使用的指令集不一样. X86架构使用CISC指令集,即复杂指令集, ...

  3. 毕昇 JDK:“传奇再现”华为如何打造 ARM 上最好用的 JDK?

    文章目录 前言 一.什么是毕昇 JDK? 1.1.毕昇 JDK 发展历程 1.2.毕昇 JDK 的支持架构 1.3.毕昇 JDK.OpenJDK 和 Oracle JDK 区别 二.为什么要做毕昇 J ...

  4. 毕昇 JDK:为啥是ARM 上超好用的 JDK

    摘要:毕昇 JDK 是华为基于 OpenJDK 定制的开源版本,是一款高性能.可用于生产环境的 OpenJDK 发行版. 本文分享自华为云社区<[云驻共创]毕昇 JDK:"传奇再现&q ...

  5. Oracle 要慌了!华为终于开源了自家的 Huawei JDK——毕昇 JDK!

    点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达 今日推荐:硬刚一周,3W字总结,一年的经验告诉你如何准备校招! 个人原创100W+访问量博客:点击前往,查看更多 没错,自 ...

  6. 鲲鹏920+OpenEuler+毕昇JDK:Neo4j信创兼容性测试

    1. 背景 "鲲鹏计算产业是基于鲲鹏处理器的基础软硬件设施.行业应用及服务,涵盖从底层硬件.基础软件到上层行业应用的全产业链条.纵观鲲鹏计算产业生态全景,硬件方面,围绕鲲鹏处理器,涵盖包括昇 ...

  7. 国信证券OA系统及质量保障体系信创建设:泰山服务器、麒麟操作系统、东方通中间件、达梦数据库、蓝凌软件、毕昇JDK

    信息技术应用创新(简称"信创")是国家重点战略,其目标是建立我国自主可控的IT底层架构和标准.国信证券作为证券行业第一批试点单位于2020年6月启动办公系统(以下简称OA系统)信创 ...

  8. Oracle慌了!华为终于对JDK下手了!

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 来源:网络 整理:公众号-码出未来 近日有开发者在华为 o ...

  9. Kona 8:鹅厂基于OpenJDK开源的JDK

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 关于Kona 8 腾讯开源的TencentKona 8是腾 ...

最新文章

  1. 概率潜在语义分析(Probabilistic Latent Semantic Analysis,PLSA)
  2. 每日一皮:公司来了个程序员鼓励师...
  3. 基于cobbler实现自动安装系统
  4. Redis内核原理及读写一致企业级架构深入剖析1-综合组件环境实战
  5. 学用awk, 在linux下批量改名
  6. 中国移动将于11月1日公布5G套餐价格,北京地区已建5000个5G基站
  7. 【Flink】IncompatibleClassChangeError: Found class org.apache.flink.streaming.runtime.tasks.Processing
  8. 智能化服务器怎么调,怎么设置dns 智能dns设置方法 【图文】
  9. 包含头文件的问题之1.7编程基础之字符串 24:单词的长度
  10. 2022安徽合肥经济技术开发区招聘社区工作者冲刺试题及答案
  11. C# ManualResetEvent 类分析
  12. C#获取注册表指定键值操作
  13. 高级API快速入门之多线程01【07】
  14. SOTIF-雨雪雾行驶场景下交通参与者视觉检测及识别
  15. oracle list分区添加,oracle 11g 如何创建、修改、删除list-list组合分区
  16. Qt图形视图框架:QGraphicsView 详解
  17. ubuntu 自动切换壁纸
  18. OmniPlayer Pro for Mac v1.4.12 支持无线投屏的视频播放器
  19. matlab常用指令
  20. 发范德萨发是空间发路口监控理发

热门文章

  1. 定档12月22日!《黑客帝国4》王者归来,再掀矩阵革命
  2. CVPR2020---30篇最新论文下载!
  3. 教育部免费开放的2.4万门网课,都在这里!
  4. php多选框怎么传值,php多选框表单checkbox参数传递的问题解析
  5. AI、ML 和数据工程 | InfoQ 趋势报告(2021 年)
  6. SAP Lumira 初探
  7. 微软和谷歌分别开源分布式深度学习框架,各自厉害在哪?
  8. 3 个重要因素,带你看透 AI 技术架构方案的可行性
  9. 什么限制了GNN的能力?首篇探究GNN普适性与局限性的论文出炉
  10. BAT大举进攻安防:互联网企业扩张“野心”