[讨论] Hotspot的源码应该怎样阅读?
jiangyingji
2011-08-17
个人觉得,如果想了解java 虚拟机的话,可以先看一眼,jcvm(java card vm),因为代码量比较小,但麻雀虽小五脏俱全,解释器,GC等都有,当然也有没有的,比如即时编译等。
同时看一下java 规范,至少对class文件的结构有一个大体的了解。 |
|
oooyooo
2013-10-16
最近在读openjdk源代码,想知道堆、栈等内存区的数据结构是怎么定义的,哪位大侠能指导下是在源码的哪里吗?谢谢了
|
|
RednaxelaFX
2013-10-16
oooyooo 写道 最近在读openjdk源代码,想知道堆、栈等内存区的数据结构是怎么定义的,哪位大侠能指导下是在源码的哪里吗?谢谢了
这个问题问得有点大。等我有空的时候再详细码字给你哈。 简单回答的话就是HotSpot VM的每个线程的调用栈、GC管理的堆这俩都是比较“含蓄”的方式管理的,所以没足够背景知识的话不太容易看懂代码。 ========================= GC堆: 其实这个还好。在VM初始化的时候通过mmap()/VirtualAlloc()来申请(reserve)了一块地址空间作为GC堆之后,用几个指针记住这块空间的首末地址和中间的区域划分。 最顶层的结构在CollectedHeap的实现类里(GenCollectedHeap、ParallelScavengeHeap、G1CollectedHeap)。 这些的里面再进一步划分出区域,每个区域记着自己的首末地址和分配指针的位置。例如GenCollectedHeap经过初始化之后里面_gens数组里会存着若干Generation,其中可能是DefNewGeneration、TenuredGeneration或者ParNewGeneration、ConcurrentMarkSweepGeneration之类,再里面又有eden_space、from_space、to_space之类的里面装着具体空间的指针。 ========================= 栈: 在正常运行的时候其实HotSpot VM根本就没有显式的数据结构用来管理栈。最多也就是Thread类的实例里有记住栈底地址(stack_base)和栈的最大大小(stack_size)。栈顶指针是直接用硬件寄存器的(例如x86-64上的rsp),所以也不需要显式的数据结构。 所谓“分配栈帧”就是把栈顶指针寄存器减去(或加上)一个大小,所谓“释放栈帧”就是把那个寄存器加上(或减去)一个大小。 但栈帧总得有结构吧?有是有,不过是隐式的,没有直接对应的C++类。在平台相关的frame_<arch>.hpp里有部分结构的描述。 OpenJDK官方wiki上有篇资料简单讲了HotSpot VM的解释器栈帧的结构,但要记住那只是HotSpot VM的栈的栈帧的其中一种可能:https://wiki.openjdk.java.net/display/HotSpot/JavaControlStack |
|
oooyooo
2013-10-16
RednaxelaFX 写道 oooyooo 写道 最近在读openjdk源代码,想知道堆、栈等内存区的数据结构是怎么定义的,哪位大侠能指导下是在源码的哪里吗?谢谢了
这个问题问得有点大。等我有空的时候再详细码字给你哈。 简单回答的话就是HotSpot VM的每个线程的调用栈、GC管理的堆这俩都是比较“含蓄”的方式管理的,所以没足够背景知识的话不太容易看懂代码。 ========================= GC堆: 其实这个还好。在VM初始化的时候通过mmap()/VirtualAlloc()来申请(reserve)了一块地址空间作为GC堆之后,用几个指针记住这块空间的首末地址和中间的区域划分。 最顶层的结构在CollectedHeap的实现类里(GenCollectedHeap、ParallelScavengeHeap、G1CollectedHeap)。 这些的里面再进一步划分出区域,每个区域记着自己的首末地址和分配指针的位置。例如GenCollectedHeap经过初始化之后里面_gens数组里会存着若干Generation,其中可能是DefNewGeneration、TenuredGeneration或者ParNewGeneration、ConcurrentMarkSweepGeneration之类,再里面又有eden_space、from_space、to_space之类的里面装着具体空间的指针。 ========================= 栈: 在正常运行的时候其实HotSpot VM根本就没有显式的数据结构用来管理栈。最多也就是Thread类的实例里有记住栈底地址(stack_base)和栈的最大大小(stack_size)。栈顶指针是直接用硬件寄存器的(例如x86-64上的rsp),所以也不需要显式的数据结构。 所谓“分配栈帧”就是把栈顶指针寄存器减去(或加上)一个大小,所谓“释放栈帧”就是把那个寄存器加上(或减去)一个大小。 但栈帧总得有结构吧?有是有,不过是隐式的,没有直接对应的C++类。在平台相关的frame_<arch>.hpp里有部分结构的描述。 OpenJDK官方wiki上有篇资料简单讲了HotSpot VM的解释器栈帧的结构,但要记住那只是HotSpot VM的栈的栈帧的其中一种可能:https://wiki.openjdk.java.net/display/HotSpot/JavaControlStack 非常感谢 |