1.Windows下编译OpenJDK9
2.了解openjdk以及为什么要使用openjdk?改源
3.openjdk和jdk性能区别
4.openjdk和oraclejdk有什么区别吗
5.OpenJDK17-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
6.一场因OpenJDK引发的血案
Windows下编译OpenJDK9
建议先阅读一下 Ubuntu下编译OpenJDK9
目标一致,下载源代码,源码然后弄出一个能用的调试JDK。
使用VMware® Workstation Pro .0.1 build-
从Java Archive Downloads - Java SE 8下载适合的改源安装包。
进行Cygwin安装
选择安装路径和下载路径,源码镜像使用清华大学的调试趣步源码下载 Tsinghua Open Source Mirror,安装基本组件包括make、改源zip、源码unzip。调试
安装完成后,改源根据需要选择其他额外组件,源码等待安装完成。调试
无需额外编译Freetype,改源OpenJDK9内部已处理。源码
使用Mercurial SCM进行源代码管理。调试
打开Cygwin Terminal,配置编译选项,执行configure和make命令。
遇到错误时,查看相关文档,解决语法问题。
清理并重新make,完成编译过程,约耗时分钟。
生成的文件夹可用于后续测试和使用。
进行基本测试以验证编译结果。
提供其他平台编译教程链接:Ubuntu下编译OpenJDK9和Mac下编译OpenJDK9
了解openjdk以及为什么要使用openjdk?
OpenJDK,全称Open Java Development Kit,是一个由Oracle和Java社区共同维护的Java平台的开源版本。它包含Java虚拟机(JVM)、Java类库和开发工具,为开发者提供了一个免费且透明的开发环境。与Oracle JDK相比,烈焰嗻天源码OpenJDK的显著优势在于其完全开源特性,这使得用户在无需支付任何许可费用的情况下,可以自由使用和修改源代码。而Oracle JDK在某些版本后可能需要商业许可,增加了使用成本。
选择OpenJDK作为Java开发工具的原因之一是,无需支付许可费用,这对于预算有限的项目或个人开发者来说尤为重要。此外,通过使用OpenJDK,开发者可以享受到社区的广泛支持,这有助于快速解决问题、获取新功能,并与全球开发者共同推动技术进步。更重要的是,保持技术的开放性和标准化是软件发展的关键,OpenJDK通过遵循Java标准,确保了不同平台和环境之间的兼容性,促进了技术的广泛采用。
虽然OpenJDK和Oracle JDK在性能和功能上非常相似,Oracle JDK实际上是在OpenJDK的基础上构建的,增加了部分商业特性。但总体而言,OpenJDK提供了一个可靠且功能全面的Java开发环境,满足了开发者对开源、免费、开放和标准化的需求。
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”显示的jdk 集合源码解析是openjdk,但是如果是使用Icedtea补丁的openjdk,显示的是java。(未验证)。
openjdk和oraclejdk有什么区别吗
区别:OpenJDK和OracleJDK之间存在一些区别。 详细解释: 开发者和版权:OpenJDK是开源的,意味着其源代码是公开的,开发者可以在其基础上自由地进行修改和发布。而OracleJDK,则是由Oracle公司开发和维护的,其源代码并不公开。Oracle是Java的一个主要提供商,拥有Java的官方认证。因此,OracleJDK具有官方支持的优势。 功能和性能:OpenJDK和OracleJDK在功能和性能上并没有显著的差异。它们都提供了Java开发所需的核心库和工具,如Java编译器、Java运行时环境等。但在某些特定情况下,OracleJDK可能包含一些额外的优化和特定的性能改进,这主要依赖于Oracle公司的持续研发和优化工作。此外,OracleJDK还包括一些商业特性支持,这对于一些大型企业来说是非常重要的。因此,在企业级应用中,往往更倾向于选择OracleJDK。但在大部分场景下,OpenJDK完全可以满足日常开发的需求。另外,由于OpenJDK的开源特性,它也吸引了很多开源项目的上古世纪遍历源码支持和发展,这使得OpenJDK在生态系统上具有更广泛的社区支持。不过要注意,由于OpenJDK可能会存在来自社区的不定期版本更新或者某些还未被彻底测试和稳定的新特性,因此在生产环境中使用时需要谨慎评估其稳定性。总的来说,选择哪种JDK主要取决于具体的应用场景和需求。两者都是高质量的工具,能够提供Java开发者需要的所有基础功能。无论是选择OpenJDK还是OracleJDK,都可以保证Java应用程序的稳定运行和开发效率。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。转载请注明来源。
一场因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版本至关重要。
å¦ä½ç¨Macå®ç¾ç¼è¯OpenJDK 7
å段æ¶é´ä¸ºäºç 究JVMï¼äºæ¯å»ä¸äºOpenJDK6ç¼è¯ä¸æï¼å°±å 为å°å£°å¡é©±å¨ï¼å没æ¥å°å¦ä½è§£å³ï¼ç»ææ»æ¯ç¼è¯ä¸æåï¼éæ¾å¼ãä½æ¯è¿æ¥è°è¯jdkæºç çæ¶åï¼åç°å¾å¤è°è¯ä¿¡æ¯é½æ²¡æï¼çå¾æé£ä¸ªè¾è¦åãæ£å¥½ä¸æåæåç¼è¯äºOpenJDK7ï¼æå°±åå»ä¸äºä¸ä¸ªè¯ç¼ï¼è½ç¶å¨CentOSä¸æåäºï¼ä½æ¯æMacä¸åç¨ä¸äºï¼æ以æå°±è±äºç¹æ¶é´å次å¨Macä¸å¼ä¸æ¬¡ãæ´ä½æ¥è¯´è¿ç®é¡ºå©ï¼ç°å¨å·²ç»å¾å¼å¿çç¨ä¸äºã
1.éæ©OS Xçæ¬å¾éè¦ã
ç®åæçMacçæ¬æ¯.ï¼ä¸å¼å§æ²¡æ³é£ä¹å¤ï¼é ç½®å¥½å¿ è¦ä¿¡æ¯ä»¥åå°±å¼å§ç¼ï¼ç»æé误满å±ãç®åçè¿ä¹ååç°æ¯ç¼è¯Cæ件çæ¶ååæ°æ误ï¼äºæ¯æ¥äºä¸ä¸ï¼æç¥éæ¯LLVMçæ¬å¤ªæ°ï¼ä¸å ¼å®¹ä½çæ¬çä¸äºç¼è¯åæ°ï¼å ·ä½çå¯ä»¥ççè¿ç¯æç« /blog/ ç第8ç¹ãæä¹ç §çä¸é¢æ¹äºç¹ä»£ç ï¼ä½æ¯ä¾æ§ç¼è¯ä¸è¿ãè¿æ¶ææ³å°ä¸ä¸ªå¾ç®åçåæ³ï¼æ¢ç¶é«çæ¬ä¸è¡ï¼æå°±è£ ä¸ªä½çæ¬çåãç±äºææ°çOS Xä¸è½è£ ä½çæ¬çXcodeï¼è£ äºXcodeæè½è£ LLVMï¼ï¼æ以å»ä¸äºä¸ä¸ª.8çOS Xè£ å¨èææºéï¼ç¶ååè£ ä¸ªXcode4.4ï¼å°ååé¢éä¸ã
è£ å¥½Xcode以åï¼è¦æå¨ä¸è½½LLVMå®è£ ãæå¼Xcodeï¼é便建ç«ä¸ä¸ªç©ºé¡¹ç®ï¼ç¶åæå¼Preferencesï¼æ¾å°å¦ä¸æ示çå°æ¹å¼å§å®è£ ï¼å 为æå·²ç»å®è£ è¿äºï¼æ以æ¯Installedï¼
第ä¸æ¥å±å°±è¿ä¹æå®äºã
2.å®è£ X
Xè¿ç©ææ¯unixç±»os使ç¨çå¾å½¢ç³»ç»ï¼.8以åçOS Xæ¯èªå¸¦çï¼ä½æ¯ä»æ¤ä»¥åå°±ä¸èªå¸¦äºã对åºäºMacï¼ä½ éè¦è£ XQuartzï¼è¿ä¸ªæ²¡æçæ¬éå¶ï¼å»ç½ä¸ä¸ææ°çå³å¯ãè£ è¿ä¸ªçåå æ¯å½æ¶å¨ç¼è¯PolicyToolsçæ¶ååºç°äºå¦ä¸é误ï¼
ld: library not found for -lX
åé¢æ¥å°äºè¿ä¸ª/hgomez/obuildfactory/wiki/Building-and-Packaging-OpenJDK7-for-OSXæå»æ³çè¯è£ ä¸ä¸XQuartzæ解å³é®é¢çã
å®è£ 以åè¦ä¸ºX建ç«è½¯è¿æ¥
sudo ln -s /usr/X/include/X /usr/include/X
3.å®è£ freetype
å¨linuxä¸ç¼è¯openjdkçæåå¯è½éå°è¿éè¦å®è£ freetypeçè¦æ±ï¼ç¶åå®è£ ä¸å¹¶å°å®è£ ç®å½å å°ç¯å¢åéé就好äºãä½æ¯OS Xä¸ä¸æ ·ï¼freetypeåç¬å®è£ å®é æ¯æ²¡ç¨çãè½ç¶åç¬å®è£ è½è®©ç¼è¯åçæ£æ¥éè¿ï¼ä½æ¯å°åé¢è¿æ¯ä¼åºéï¼è³äºåå æ没æ¾å°ãé£æä¹åå¢ï¼å®é ä¸å¦æå®è£ 好Xï¼freetypeå°±ä¸èµ·å®è£ 好äºï¼å¤§å®¶å¯ä»¥å»Xçç®å½éççæ¯å¦æfreetypeã
è½ç¶è¯´å®è£ äºXå°±èªå¸¦freetypeï¼ä½æ¯ç¼è¯è¿ç¨ä¸å¯è½ä¼åºç°å¦ä¸é误ï¼
error: freetype/config/ftheader.h: No such file or directory
å®é ä¸å°±æ¯ç®å½é®é¢ï¼æ§è¡ä¸é¢è¿å¥å½ä»¤å°±å¥½äºï¼
sudo ln -s /usr/X/include/freetype2/freetype/ /usr/X/include/freetype
4. é ç½®ç¯å¢åé
åå¨Linuxä¸ç¼è¯ç¸æ¯ï¼OS Xçç¯å¢åéé ç½®ç¸å¯¹æ¥è¯´ç®åå¾å¤ãåªéè¦é ç½®ç¼è¯éè¦çjdkållvmçç®å½å°±å¯ä»¥äºã
å 为å¾å¤æºä»£ç é½æ¯ç¨æ¬æºç°æçjdkæ¥ç¼è¯ï¼æ以é¢è£ ä¸ä¸ªä½çæ¬çjdkæ¯å¿ é¡»çï¼è¿éæ们éè¦å®è£ jdk6ãå®è£ 好以åï¼æ¾å°å ¶å®è£ ç®å½ï¼å¹¶æ·»å å¦ä¸ç¯å¢åéï¼
[plain] view plaincopy
export ALT_BOOTDIR=/System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home
é常æ¥è¯´å®è£ ç®å½é½åºè¯¥å¨/System/Library/Java/JavaVirtualMachinesç®å½ä¸ãå¦æä¸å¨çè¯ï¼æ个æå·§å¯ä»¥æ¾å°ãå 为å®è£ 好jdk以åï¼ç³»ç»ä¼èªå¨å¨/usr/binä¸å»ºç«æåjavaå½ä»¤ç软è¿æ¥ï¼æ以æ§è¡âls -l /usr/bin/javaâå°±è½çå°è¿ä¸ªå½ä»¤æååªï¼ç¶åè¿ä¹é¡ºçæ¾ä¸å»å°±è½æ¾å°ã
llvmæ¯ç¼è¯Cç±»æ件æå¿ é¡»çï¼æ以è¦æå®çæå¨ç®å½æ·»å å°ç¯å¢åééãé常OS Xä¸å®è£ appé½ä¼æapp移å°Applicationsç®å½ä¸ï¼æ以ææåå®è£ Xcodeçæ¶åä¹æä»ç§»è¿å»äºï¼å¦æä½ æXcodeæ¾å¨äºå«çç®å½ï¼é£å°±æ¾å°å¯¹åºçç®å½å³å¯ã
[plain] view plaincopy
export ALT_COMPILER_PATH=/Applications/Xcode.app/Contents/Developer/usr/bin
5.è·åç¼è¯æºç
æç §è¿ä¸é¢ç第ä¸ç¹è·åæºä»£ç /arungupta/entry/build_open_jdk_7_on å¦æ没æè£ hgçéè¦èªè¡å®è£
å°ç°å¨ä¸ºæ¢ï¼ç¼è¯åçåå¤å·¥ä½å·²ç»å®æãæ们å¯ä»¥å æ§è¡make sanityæ§è¡ä¸ç¼è¯åçæ£æ¥ãå¦ææ£æ¥éè¿ï¼å æ¥ççå ·ä½çç¼è¯å½ä»¤ï¼
[plain] view plaincopy
make ALLOW_DOWNLOADS=true SA_APPLE_BOOT_JAVA=true SKIP_DEBUG_BUILD=false SKIP_FASTDEBUG_BUILD=false ALWAYS_PASS_TEST_GAMMA=true HOTSPOT_BUILD_JOBS=`sysctl -n hw.ncpu`
è¿éæ两个é®é¢ï¼
a. ALLOW_DOWNLOADS=true表示ç¼è¯è¿ç¨ä¸å 许ä¸è½½ãå 为æäºç¼è¯æ¨¡åï¼æ¯å¦jaxpï¼ç¼è¯èæ¬ä¸æå®äºéè¦ä¸è½½ç¹å®çå ãè½ç¶æ没è¯è¿è®¾ç½®æfalseä¼ä¸ä¼å½±åç¼è¯ï¼ä½æ¯è¿æ¯æ¨è设置ætrueãä½æ¯è¿å°±å¸¦æ¥å¦ä¸ä¸ªé®é¢ï¼ä¸è½½è¿ç±»å å¾è´¹æ¶é´ï¼ææ¶åå°±ä¼å¨é£å¡å¾é¿æ¶é´ï¼æ以ææ ¹æ®ç¼è¯æ¥å¿æ¾å°ç¼è¯èæ¬ä¸æ§å¶ä¸è½½çå ·ä½å½ä»¤ï¼ä¿®æ¹ä¿®æ¹å¹¶ä¸æç¨è¿ é·ä¸ç对åºå æ¾å°æ£ç¡®ç®å½ä¸ï¼ç¶åéæ°ç¼è¯ä¸éï¼å°±è½é¡ºå©éè¿äºãè¿ä¸ç¹åé¢æä¼è¯¦è¯´ã
b. SKIP_DEBUG_BUILD=false SKIP_FASTDEBUG_BUILD=falseè¿ä¸¤ä¸ªè¡¨ç¤ºç¼è¯åºæ¥çjdkæè hotspotæ¯å¦å¯ä»¥debugãFASTDEBUG表示çåºè¯¥æ¯æä¾ç®åçdebugåè½ï¼å¦ææ³è¦å®æ´çdebugï¼åSKIP_DEBUG_BUILDå¿ é¡»è®¾ç½®ä¸ºfalseãä¸è¿è¿éæéä¸ç¹ï¼å¦ææ³å¨debug jdkçæ¶åè½çå°debugä¿¡æ¯ï¼æ¯å¦åéåçï¼åªéè¦SKIP_FASTDEBUG_BUILD设置为falseå°±å¯ä»¥äº
å¦æè¿ä¸¤ä¸ªé®é¢é½ä¸æ¯é®é¢ï¼é£ä¹ä½ å°±å¯ä»¥æå车äºãå¦ædebugåfastdebugé½æ¯falseï¼åå ä¸ç¨èææºç¼è¯ï¼æ以éè¦çæ¶é´ä¼æ¯è¾é¿ï¼ä½ ä¹è®¸éè¦æ¾ä¸é¨é¿ä¸ç¹ççµå½±æ¥æ¶ç£¨ä¸ä¸äºãæåç¼è¯åºæ¥çç»ææ¯è¿æ ·çï¼
j2sdk-imageå°±æ¯ä½ èªå·±ç¼è¯åºæ¥çjdkï¼å¯ä»¥ç´æ¥ç¨äºãè³äºå ¶ä»ç®å½ä¸çå 容ï¼åä½èªå·±ç¢ç£¨å§ã
ç°å¨æ¥è¯´ä¸ALLOW_DOWNLOADS=trueå¼èµ·çé®é¢ã
ç¼è¯è¿ç¨ä¸è¦ä¸è½½å¤å°å æä¸æ¸ æ¥ï¼ä½æ¯æ个人éå°ä¸è½½å¾ä¹ çå æ»å ±æä¸ä¸ªï¼
jaxp_.zipãjdk7-jaf-__.zipãjdk7-jaxws2_2_4-b-__.zip
æä¹å说è¿å¯ä»¥ä¿®æ¹ç¼è¯èæ¬è·³è¿ä¸è½½å¹¶ä¸ç¨æ们已ç»ä¸è½½å¥½çï¼ä½æ¯å®é ç¼è¯è¿ç¨ä¸ï¼è¿ä¸ä¸ªå 对åºççç¼è¯èæ¬æ¯å¨æçæçï¼æä»¥ä½ åªè½çå°ä»å¡å¨é£äºï¼æè½åä¸æ¥å¹¶æ¾å°èæ¬ä¿®æ¹ä¹ãå æ¤å 为è¿ä¸ä¸ªå ï¼æ们æ»å ±éè¦å3次ãè½ç¶æç¹èç¼ï¼ä½æ¯æ¯èµ·ä¸ç´å¡å¨é£å¥½å¤ªå¤äºã
å设æ们ç¼è¯çæ¯æ®éçæ¬ï¼å³éDEBUGåéFASTDEBUGãä¸é¢ä»¥jaxp_.zip为ä¾å讲ä¸ä¸æä¹ä¿®æ¹å¯¹åºèæ¬ï¼
èæ¬æå¨ä½ç½®ï¼openjdkæ ¹ç®å½/build/macosx-universal/jaxp/build/xml_generated/build-drop-jaxp_src.xml
openjdk和sunjdk有啥区别?
了解
使用Linux系统的人通常会遇到内置或通过软件源安装的JDK是OpenJDK的情况。那么,OpenJDK是什么?它与SUN JDK有什么区别?历史背景是,OpenJDK是JDK的开源版本,以GPL协议(通用公共许可证)形式发布。在JDK7时期,OpenJDK作为其主要开发版本,而SUN JDK7是在OpenJDK7基础上发布的,两者在大部分代码上相同,仅在少量代码上有所替换。SUN JDK则采用JRL(Java研究授权协议)发布。
授权协议的不同是关键点。OpenJDK遵循GPL V2,允许商业使用,而SUN JDK则为个人研究使用。OpenJDK不包含部署功能,如浏览器插件、Java Web Start和Java控制面板。此外,OpenJDK的源代码存在不完整性,因为某些代码由于版权问题无法开放。这部分代码通常被替换为功能类似的开源代码,比如字体栅格化引擎使用Free Type代替。OpenJDK更精简,仅包含基础JDK,不包括其他软件包,如Rhino、Java DB、JAXP等。在OpenJDK中,无法使用Java商标。
总的来说,OpenJDK和SUN JDK之间主要区别在于授权协议、功能完整性、源代码的可用性和商标使用。希望未来Oracle能够更开放地参与JCP(Java社区过程),实现Java生态系统的自由发展。
OpenJDK有何优势?
OpenJDK与JDK的主要区别在于其开源性和社区发展。 详细解释: 1. JDK与OpenJDK的基本概念 JDK是一整套用于开发Java应用程序的工具包,包括编译器、解释器、调试器和其他实用工具。它是Oracle公司提供的官方Java开发工具包。而OpenJDK则是JDK的开源版本,由开放源代码社区维护和发展。两者的目标是相同的,即提供一个Java程序开发环境,但在源代码的开放性及社区参与上存在区别。 2. 源代码开放性 JDK的源代码是封闭的,由Oracle公司控制。这意味着开发者无法直接访问和修改JDK的源代码。而OpenJDK则是完全开源的,任何人都可以访问其源代码并参与开发。这使得OpenJDK可以从社区中获得更广泛的反馈和改进建议,进而持续改进和优化。 3. 社区发展 由于OpenJDK是开源的,它吸引了大量的开发者参与和贡献。全球各地的开发者可以通过提交代码、修复错误和提供建议来推动OpenJDK的发展。而JDK则主要依赖于Oracle公司的开发团队进行维护和更新。这意味着OpenJDK可能获得更快的更新和修复速度,同时更能反映全球开发者的需求和创新思维。 4. 兼容性 虽然OpenJDK和JDK在功能和性能上大体相似,但为了保证与官方Java标准的一致性,OpenJDK通常也能提供与JDK相似的兼容性。这意味着在大多数情况下,使用OpenJDK开发的Java应用程序可以在JDK上顺利运行。但具体兼容性可能会受到版本更新和特定应用场景的影响。