1.OpenJDK17-JVM 源码阅读 - ZGC - 并发标记 | 京东物流技术团队
2.在安装完jdk后,jdk中的常用包放在哪里,比如java.io类,java.sql类放在哪里?
3.java怎么写
OpenJDK17-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。转载请注明来源。
在安装完jdk后,jdk中的常用包放在哪里,比如java.io类,java.sql类放在哪里?
JVM的仓库进存源码常用包一般在C:\Program Files\Java\jre1.5.0_\lib\rt.jar
一般都会放在C:\Program Files\Java\jre1.5.0_\lib下
jdk的一般在C:\Program Files\Java\jdk1.5.0_\jre\lib
源代码在C:\Program Files\Java\jdk1.5.0_\src.zip
java调用的包像String啊这些自带的包的源代码都可以在这里找到。
一般碰到不会用的类都是直接去看API文档的。
很少来翻源文件。
除非你想研修下工业版的java代码。
不过看看也是有好处的。
java怎么写
实现一个java程序,主要有三个步骤:1、编写源代码,2、编译源代码,3、运行。java的源代码必须先编译,然后才能由JVM解析执行。所以我们程序员第一步的工作就是要编写java的源代码文件,java的源代码文件其实就是以.java为后缀名的普通的文本文件。下面我们以Window系统为例,实现我们的第一个也是非常简单的一个,同时也是一个非常经典的一个应用程序——打印Hello world。一、编写源代码
1、 首先,在D盘下建立任意建立一个目录(建议是非中文的目录),这里我建立的目录是javacode。然后进入该目录,在该目录下建立一个文件名是:HelloWorld.java的普通文件。
2、 使用文本打开该文件。然后输入一下内容,初学要特别注意单词的大小写和每个单词之间都必须要有空格,还得注意大括号和分号等符号。
/
*** 我的第一个应用程序
* @author Administrator
*
*/
public class HelloWorld {
public static void main(String[] args) {
System.out.println("hello world!");//输出hello world;
}
}
二、编译源文件。
1、 进入DOS环境。点击开始,在运行中输入cmd后回车即可进入DOS环境。
2、 在命令行方式下,进入到程序所在的目录d:/ javacode,执行javac HelloWorld.java命令,对程序进行编译
编译完成之后可以发现在目录之中多了一个HelloWorld.class的文件,此文件就是编译成功后生成的字节码文件,需要JVM解析执行。
三、运行应用程序。
程序编译之后,接下来我们就可以运行该应用程序了,继续在DOS环境下使用java命令,输入java HelloWorld,即可执行程序,输出一句“hello,world!”。具体的操作过程可以参考下图。
如果一切都没有问题,那么我们第一个应用程序就完成了,虽然有很多地方我们可能还没有明白,以后我们会慢慢讲解。
四、命令行工具
上面使用到的java和javac命令都是JDK提供给我们的一些命令行工具,除此之外还有很多命令行工具。JDK包含的基本命令如下:
javac – 编译器,将源代码程序编译成为字节码文件。
jar – 打包工具,将相关的字节码文件打包成一个jar文件。
javadoc – 文档生成器,从源代码注释中提取信息,并生成文档,以便于查看。
jdb – debugger,调试工具。
java – 运行编译后的java程序。
appletviewer:小程序浏览器,一种执行HTML文件上的Java小程序的Java浏览器。
Javah:是java语言 C 头文件和存根文件生成器。
Javap:Java反编译工具,显示编译类文件中的可访问功能和数据,可用于分析代码。
Jconsole:进行系统调试和监控的工具。
★什么是环境变量?★
也许现在你会问为什么要配置这些环境变量?首先理解一下什么是环境变量。环境变量是指在操作系统中用来指定操作系统运行环境的变量。Java_home变量定义了JDK的安装目录,path变量是当系统运行一个命令程序不需要告诉它程序所在的完整路径时,系统除了在当前目录下面寻找此命令外,还会根据path中指定的路径去找。用户通过设置环境变量,可以更好的运行进程。设置Classpath的目的,在哪些目录下可以找到您所要执行的Java程序所需要的类或者包。