1.Oracle JDK 和 OpenJDK 有什么区别?
2.openjdk和jdk的码包区别是什么?
3.一场因OpenJDK引发的血案
4.openjdk和jdk性能区别
5.JDK在Linux上的安装路径定义jdklinux路径
6.详细过程ubuntu下面编译openJDK8,修改源码IDEA中调试
Oracle JDK 和 OpenJDK 有什么区别?
OpenJDK和Oracle JDK是Java开发工具包(JDK)的两个版本,它们之间存在一些关键区别。码包首先,码包OpenJDK是码包一个开源项目,源自Sun Microsystems在年将Java源代码开源。码包OpenJDK的码包文件同步软件源码源码是可复用的,如IcedTea和UltraViolet等发行版就是码包基于OpenJDK源码衍生的。
另一方面,码包Oracle JDK采用了商业实现,码包它在开源的码包FreeType基础上使用。虽然两者在共有的码包组件基础上类似,Oracle JDK包含了一些OpenJDK中没有的码包、商业封闭的码包功能。例如,码包从JRockit移植而来的码包Java Flight Recorder以及JRockit的MissionControl在HotSpot之后也将作为Oracle JDK的专有、封闭特性提供。
在技术层面上,Oracle的项目发布经理Joe Darcy在OSCON 上指出,OpenJDK 7和Oracle JDK 7在程序上非常接近,两者共享大量相同的代码。编译的OpenJDK在性能、功能和执行逻辑上与官方Oracle JDK一致。
在大多数Linux发行版本中,内置或通过软件源安装的JDK通常为OpenJDK。简而言之,OpenJDK是JDK的开源版本,采用GPL V2协议发布,而Oracle JDK采用JRL协议发布。两者的区别在于授权协议的不同、包含的软件包数量、源代码完整性、无法访问的部分源代码的处理方式以及是否可以使用Java商标。
除了原生的OpenJDK,还有IcedTea项目,它是为了填补OpenJDK中由于产权问题而造成的缺失部分而创立的。IcedTea提供了一套完整的瑞幸 源码开源工具链及代码库,特别是针对Java Web Start基础架构,它在构建OpenJDK时提供了多种不同的模式,如使用Zero Assembler Port在非x/sparc芯片上支持编译。
此外,Oracle JDK可能包含了被替换成功能相同的开源代码的部分源代码,例如字体栅格化引擎使用了Free Type代替。然而,使用OpenJDK的机器上,“java -version”显示的通常会是OpenJDK,而不是Oracle JDK,除非通过IcedTea补丁。
总结而言,OpenJDK和Oracle JDK之间的主要区别在于开源许可、包含的功能集、源代码可用性以及商标使用权限。选择哪个版本取决于开发者或组织的特定需求、项目许可条件和兼容性考量。
openjdk和jdk的区别是什么?
OpenJDK与JDK的主要区别在于其开源性和社区发展。 详细解释: 1. JDK与OpenJDK的基本概念 JDK是一整套用于开发Java应用程序的工具包,包括编译器、解释器、调试器和其他实用工具。它是Oracle公司提供的官方Java开发工具包。而OpenJDK则是JDK的开源版本,由开放源代码社区维护和发展。两者的目标是相同的,即提供一个Java程序开发环境,但在源代码的开放性及社区参与上存在区别。 2. 源代码开放性 JDK的源代码是封闭的,由Oracle公司控制。这意味着开发者无法直接访问和修改JDK的源代码。而OpenJDK则是完全开源的,任何人都可以访问其源代码并参与开发。这使得OpenJDK可以从社区中获得更广泛的反馈和改进建议,进而持续改进和优化。bing源码泄露 3. 社区发展 由于OpenJDK是开源的,它吸引了大量的开发者参与和贡献。全球各地的开发者可以通过提交代码、修复错误和提供建议来推动OpenJDK的发展。而JDK则主要依赖于Oracle公司的开发团队进行维护和更新。这意味着OpenJDK可能获得更快的更新和修复速度,同时更能反映全球开发者的需求和创新思维。 4. 兼容性 虽然OpenJDK和JDK在功能和性能上大体相似,但为了保证与官方Java标准的一致性,OpenJDK通常也能提供与JDK相似的兼容性。这意味着在大多数情况下,使用OpenJDK开发的Java应用程序可以在JDK上顺利运行。但具体兼容性可能会受到版本更新和特定应用场景的影响。一场因OpenJDK引发的血案
在进行项目开发时,遇到了一个令人头疼的问题。在本地调试一切正常,但将项目部署到服务器上时,却遇到了编译失败的情况。问题出在缺少一个名为javafx.util的库。经过排查,发现原因在于服务器上使用的JDK版本是OpenJDK,而非本地开发环境中的Oracle JDK。
OpenJDK是一个开源版本的JDK,其与Oracle JDK在功能上存在一定的差异。从历史来看,OpenJDK在JDK 7时期已成为JDK 7的主干开发,而在JDK 7的发布中,OpenJDK与Oracle JDK的大部分原始代码相同,只有少量部分有所区别。这种差异主要体现在一些商业功能的实现上,例如Oracle JDK中包含了Flight Recorder和Java Mission Control等功能,而OpenJDK则使用了开源的FreeType作为字体渲染器。
由于OpenJDK是一个开源项目,开发者可以自行克隆其源代码或下载源码包进行编译,从而生成定制化的飞鸽源码下载JDK版本。基于OpenJDK的源码,还诞生了许多其他版本的JDK,如IcedTea、UltraViolet等。因此,服务器上使用的OpenJDK版本可能缺少某些特定的库,如javafx.util。
要解决这个问题,可以通过以下几种方式:
1. 确保在服务器上安装了包含javafx.util库的JDK版本,或者通过下载该库的jar包,并将其添加到项目中。
2. 将本地编译好的项目部署到服务器上,并确保服务器上的JDK版本兼容。
3. 考虑使用Oracle JDK作为服务器上的JDK版本,因为Oracle JDK在商业许可下提供稳定的更新和支持。
4. 在本地编译项目时,使用jar包部署项目,以避免与服务器上JDK版本的兼容性问题。
通过上述方法,可以解决因使用OpenJDK导致的编译错误问题,并确保项目在不同环境下的顺利运行。在选择JDK版本时,考虑到项目需求、稳定性以及社区支持等因素,选择合适的JDK版本至关重要。
openjdk和jdk性能区别
关于JDK和OpenJDK的区别,可以归纳为以下几点:
1、授权协议的不同:openjdk采用GPL V2协议放出,而JDK则采用JRL放出。两者协议虽然都是开放源代码的,但是在使用上的不同在于GPL V2允许在商业上使用,而JRL只允许个人研究使用。OpenJDK不包含Deployment(部署)功能部署的功能包括:Browser Plugin、Java Web Start、以及Java控制面板,系泊系统源码这些功能在Openjdk中是找不到的。
2、OpenJDK源代码不完整。这个很容易想到,在采用GPL协议的Openjdk中,sun jdk的一部分源代码因为产权的问题无法开放openjdk使用,其中最主要的部份就是JMX中的可选元件SNMP部份的代码。而Icedtea则为这些不完整的部分开发了相同功能的源代码(OpenJDK6),促使OpenJDK更加完整。
3、部分源代码用开源代码替换。由于产权的问题,很多产权不是SUN的源代码被替换成一些功能相同的开源代码,比如说字体栅格化引擎,使用Free Type代替。
4、openjdk只包含最精简的JDK。OpenJDK不包含其他的软件包,比如Rhino Java DB JAXP……,并且可以分离的软件包也都是尽量的分离,但是这大多数都是自由软件,你可以自己下载加入。
5、不能使用Java商标。这个很容易理解,在安装openjdk的机器上,输入“java -version”显示的是openjdk,但是如果是使用Icedtea补丁的openjdk,显示的是java。(未验证)。
JDK在Linux上的安装路径定义jdklinux路径
Java程序设计语言(Java)由Sun Microsystems提出的一种用于开发应用程序的平台无关的面向对象编程语言。为了实现Java程序,需要通过安装Java程序软件来构建运行时环境(JRE)和开发时环境(JDK),这两个软件包都是Java的必备库,而在Linux上安装Java时,也是必须要安装JDK和JRE的,下面我们就来讨论一下在Linux上安装JDK的安装路径定义的事情。
首先,在Linux上安装JDK,有两种常见的途径,一种是使用源码包安装,另一种是使用包安装管理程序。使用源码包安装的方法是将源码文件下载到本地,然后在控制台上使用tar或rpm安装,安装结束后,JDK就安装完成了。另一种方式,首先按照Linux系统版本使用yum或apt等包管理工具安装openjdk,然后从Oracle网站上下载相应系统版本的JDK,然后使用rpm或tar命令安装就可以了。
安装完JDK后,下一步就是要定义安装时可以定义的路径,通常在Linux上,JDK会安装到/opt/ folder中,例如:
/opt/java/jdk1.8.0_xx
其中xx表示Java的版本号,其余路径也是类似的,安装完成之后,需要设置环境变量JAVA_HOME,例如:
export JAVA_HOME=/opt/java/jdk1.8.0_xx
最后一步,需要加入到用户变量PATH中,例如:
export PATH=$JAVA_HOME/bin:$PATH
以上只是安装时定义的一种参考路径,实际安装时可以根据用户的具体需求,更改相应的安装路径,以安装不同版本的JDK,可以在不同的路径中互相安装,同时设置不同的环境变量,使之仅影响其中一个JDK环境。总之,在Linux上安装JDK时,推荐手动安装源码,定义安装路径,在源码安装完成后,添加环境变量,就可以完成绝大部分的安装,如果有多个版本的JDK要同时安装,只需要使用不同的目录安装,并定义不同的环境变量即可。
详细过程ubuntu下面编译openJDK8,修改源码IDEA中调试
编译JDK源码的最佳实践是亲手操作,理解其流程。网上有许多教程,但只有实际操作,才能深刻理解整个过程。
首先,环境准备上选择Ubuntu .,因为在此版本下,编译过程中遇到的异常较少。使用低版本Ubuntu的主要目的是为了专注于编译源码和阅读源码,而不是研究版本兼容性问题。高版本的OpenJDK理论上可行,但这里更多是选择已熟悉使用的OpenJDK 8版本。
获取OpenJDK 8源码有两种方式:利用Mercurial(hg)或手动下载。Mercurial是OpenJDK使用的代码管理工具,通过hg clone命令下载源码。在遇到执行卡死问题后,改用手动下载方式。
下载地址为jdk.java.net,选择相应版本下载。下载后得到openjdk-8u-src-b-_jan_.zip,解压后重命名为openjdk8。
接着,需要安装基础JDK作为编译环境。可选择手动下载已编译好的JDK7作为引导JDK,如openjdk-7u-b-linux-x-_dec_.tar.gz。解压并重命名后,配置系统环境变量,确保编译过程顺利进行。
安装编译所需的依赖,并检查是否遗漏。执行命令检查依赖,如有缺失,按照提示进行安装。ccache配置后出现版本过旧的提示,不影响编译。
编译前需进行一系列检查:设定语言选项、查看PATH环境变量、清除JAVA_HOME变量,确保编译环境配置正确。执行make all命令,过程中可能会遇到报错,通过修改相关源文件,如hotspot/make/linux/Makefile的SUPPORTED_OS_VERSION变量,添加4%,解决内核版本问题。
验证编译成功,通过执行java -version命令确认。编译后源码使用,如创建Test.java源文件,通过Javac编译器编译为Test.class文件。运行Test.class文件,输出信息确认编译成功。
在IDEA中使用JDK源码调试,首先安装IntelliJ IDEA,下载并解压到opt目录,通过idea.sh启动。将编译好的JDK导入IDEA,配置debug,去掉Before launch中的build选项,执行测试代码。
为了更方便地查看源码,可以修改JDK源码,如为System.out.println添加打印前缀。修改源码后重新编译,执行测试代码以验证修改效果。
通过实际操作和实践,对JDK源码的理解将更加深入。本指南提供了一个完整的编译和调试流程,帮助开发者深入理解JDK源码的细节。
OpenJDK-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
ZGC简介:
ZGC是Java垃圾回收器的前沿技术,支持低延迟、大容量堆、染色指针、读屏障等特性,自JDK起作为试验特性,JDK起支持Windows,JDK正式投入生产使用。在JDK中已实现分代收集,预计不久将发布,性能将更优秀。
ZGC特征:
1. 低延迟
2. 大容量堆
3. 染色指针
4. 读屏障
并发标记过程:
ZGC并发标记主要分为三个阶段:初始标记、并发标记/重映射、重分配。本篇主要分析并发标记/重映射部分源代码。
入口与并发标记:
整个ZGC源码入口是ZDriver::gc函数,其中concurrent()是一个宏定义。并发标记函数是concurrent_mark。
并发标记流程:
从ZHeap::heap()进入mark函数,使用任务框架执行任务逻辑在ZMarkTask里,具体执行函数是work。工作逻辑循环从标记条带中取出数据,直到取完或时间到。此循环即为ZGC三色标记主循环。之后进入drain函数,从栈中取出指针进行标记,直到栈排空。标记过程包括从栈取数据,标记和递归标记。
标记与迭代:
标记过程涉及对象迭代遍历。标记流程中,ZGC通过map存储对象地址的finalizable和inc_live信息。map大小约为堆中对象对齐大小的二分之一。接着通过oop_iterate函数对对象中的指针进行迭代,使用ZMarkBarrierOopClosure作为读屏障,实现了指针自愈和防止漏标。
读屏障细节:
ZMarkBarrierOopClosure函数在标记非静态成员变量的指针时触发读屏障。慢路径处理和指针自愈是核心逻辑,慢路径标记指针,快速路径通过cas操作修复坏指针,并重新标记。
重映射过程:
读屏障触发标记后,对象被推入栈中,下次标记循环时取出。ZGC并发标记流程至此结束。
问题回顾:
本文解答了ZGC如何标记指针、三色标记过程、如何防止漏标、指针自愈和并发重映射过程的问题。
扩展思考:
ZGC在指针上标记,当回收某个region时,如何得知对象是否存活?答案需要结合标记阶段和重分配阶段的代码。
结束语:
本文深入分析了ZGC并发标记的源码细节,对您有启发或帮助的话,请多多点赞支持。作者:京东物流 刘家存,来源:京东云开发者社区 自猿其说 Tech。转载请注明来源。