1.å¨linuxä¸å®è£
jdk1.8å¨linuxä¸å®è£
jdk
2.OpenJDK17-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
3.Spring源码 1.源码的码下下载与编译(by Gradle)
å¨linuxä¸å®è£ jdk1.8å¨linuxä¸å®è£ jdk
JDK1.8æä¹ä¸è½½ï¼æ¹æ³/æ¥éª¤
第ä¸æ¥ï¼ä¸è½½linuxç¯å¢ä¸çjdk1.8ï¼è¯·å»ï¼å®ç½ï¼ä¸ä¸è½½jdkçå®è£ æ件ï¼
第äºæ¥ï¼æ°å»º/usr/javaæ件夹ï¼å°jdk-8u-linux-i.tar.gzæ¾å°è¯¥æ件夹ä¸ï¼å¹¶å°å·¥ä½ç®å½åæ¢å°/usr/javaç®å½ä¸ã
第ä¸æ¥ï¼éè¿ä»¥ä¸æ¥éª¤ï¼jdk1.8就已ç»å ¨é¨å®è£ å®æäº
第åæ¥ï¼é ç½®ç¯å¢åéï¼â ã使ç¨vim/etc/profileç¼è¾profileæ件ï¼å¦ä¸1å¾æ示ï¼â¡ãå¨/etc/profileåºé¨å å ¥å¦ä¸å 容ï¼
java_home=/usr/java/jdk1.8.0_path=$java_home/bin:$pathclasspath=$java_home/jre/lib/ext:$java_home/lib/tools.jarexportpathjava_homeclasspath
第äºæ¥ï¼æå使ç¨source/etc/profile让profileæ件ç«å³çæã
第å æ¥ï¼å½ä»¤æµè¯
â ã使ç¨javacå½ä»¤ï¼ä¸ä¼åºç°commandnotfoundé误
â¡ã使ç¨java-versionï¼åºç°çæ¬ä¸ºjavaversion"1.8.0_"
â¢ãecho$java_home,echo$classpath,echo$pathï¼ççèªå·±çé ç½®æ¯å¦é½æ£ç¡®ã
å¦ä½å¨Linuxç³»ç»ä¸å®è£ 软件ï¼
ç®åLinuxç¨æ·éæå¤çç³»ç»æ¯Centosï¼ç®åææ°å¤§çæ¬æ¯Centos7,ç³»ç»è½»é级ï¼å 费使ç¨ã
å¦ä½å¨Linuxä¸å®è£ 软件ï¼æ说å 个æ¹æ³:
ä¸.使ç¨rpmç±»åç软件å è¿è¡å®è£ ï¼è½ç¶æå¨æåé¢ä½æ¯æä¹ä¸æ¨èæ°æ使ç¨ï¼å 为æä¾èµçå ä¼å¾å¤ã
1.ä»å®ç½ä¸è½½rpm软件å ï¼ç´æ¥éè¿å½ä»¤
rpm-ivh软件å å
å¦ææ¯é¿éäºæå¡å¨å¯ä»¥ä½¿ç¨å½ä»¤ã
2.å¦æéåæºé常æ°ï¼ç³»ç»å¯ä»¥èç½ï¼ä½¿å¾yuminstall软件å åæ¥å®è£ å¾æ¹ä¾¿ã
äºãæºç å®è£ ï¼æ¨è使ç¨ï¼
æºç ç±»çå®è£ ï¼ä¸»è¦çæ¥éª¤å¦ä¸:
ä¸è½½å¥½è½¯ä»¶å
1.解åå®è£ æºæ件tar-zxvftest.tar.gz
2.è¿å ¥å°è§£ååçç®å½cdtest
3../configure
4.make
5.makeinstall
以è¿ä»¥ä¸æ¥éª¤å³å¯å®ææºç å 软件çå®è£ ã
为ä»ä¹è¦æ¨èè¿ä¸ªå¢ï¼å 为è¿æ ·å¯ä»¥èªå·±éæ©æéè¦è½¯ä»¶ççæ¬ã
jdkå linuxå¯ä»¥å¨windowsç¨åï¼
å¨æç认ç¥èå´å æ¯ä¸å¯ä»¥ç
oracleå®æ¹åå«æä¾äºåºäºLinuxåwindowsä¸åç³»ç»çæ¬çjdkå®è£ å ï¼ä½ å¯ä»¥æ ¹æ®èªå·±çç³»ç»ç±»å,ç³»ç»å ·ä½ä½æ°å»éæ©åéçjdkçæ¬è¿è¡ä¸è½½ï¼ä»¥åoracleæ éç»å½å³å¯ä¸è½½ï¼ç°å¨éç»å½æè½ä¸è½½ï¼æ³¨åä¸ä¸ªå è´¹çè´¦æ·ï¼ç»å½å°±å¯ä»¥äºï¼
OpenJDK-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
ZGC简介:
ZGC是Java垃圾回收器的前沿技术,支持低延迟、码下大容量堆、码下染色指针、码下读屏障等特性,码下自JDK起作为试验特性,码下lammps源码分析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。转载请注明来源。
Spring源码 1.源码的下载与编译(by Gradle)
为了获得Spring源码并成功编译,我们首先需要下载源码。方法之一是使用Git clone命令,前提是我们已安装Git。但要注意,最新版本可能需要JDK ,若需使用JDK 8,推荐选择较旧版本。GitHub上,最新稳定版本为5.2..RELEASE,这是一个GA(General Availability)版本,表示正式发布的版本,适合在生产环境中使用。如果你使用的是JDK 8,建议选择分支版本。
如果GitHub服务不可用或下载速度缓慢,可以考虑从其他资源库下载。例如,可以使用csdn提供的资源链接支持作者,或者直接从gitee下载源码。
下载源码后,导入IDEA并选择Gradle工程。IDEA会自动加载,但可能遇到一些报错。如果报错提示“POM relocation to an other version number is not fully supported in Gradle”,需要将xml-apis的版本号更改为1.0.b2。这可以通过在项目的build.gradle文件中添加指定版本的代码来实现。
加载并配置新模块后,可以通过新建测试类来进行验证。在build.gradle中添加配置,并在模块中新建文件,包括一个启动类、一个配置类和一个实体类。记得刷新Gradle,进行测试。
测试结果应显示新建的实体类已被Spring容器加载。如果在测试中遇到问题,可以通过检查编译工具、编译器和项目结构来解决。确保使用本地Gradle路径、选择JDK 1.8版本,并在项目设置中选择正确的JDK版本。