[讨论] Hotspot的源码应该怎样阅读?
woosheep
2011-08-05
下了Hotspot的源码包,解开里面有各种源文件和各种文件夹,看得有点乱
不知道有没有文档说明或者源码树之类的介绍? 也想顺便请教一下大家,Hotspot的源码量还是比较大的,应该怎样阅读才能比较好地把握hotspot实现jvm的架构和细节? |
|
RednaxelaFX
2011-08-05
楼主下载的是哪个源码包?
不同的包之间代码结构不完全一样,最好是有针对性的来说。 |
|
woosheep
2011-08-05
hotspot-9b0ca45cd756.zip,在openJDK的hotspot里下的
我还以为就是代码内容改了,原来架构还不一样 刚学,还有好多不懂,各位多指教 |
|
RednaxelaFX
2011-08-05
不是“架构”不一样,是目录结构不一样。
如果你下的只是HotSpot VM的代码的话那好办,Oracle JDK 6/Oracle JDK 7/OpenJDK 6/OpenJDK 7里的HotSpot VM基本上目录结构都是一样的。 ├─agent Serviceability Agent的客户端实现 ├─make 用来build出HotSpot的各种配置文件 ├─src HotSpot VM的源代码 │ ├─cpu CPU相关代码(汇编器、模板解释器、ad文件、部分runtime函数在这里实现) │ ├─os 操作系相关代码 │ ├─os_cpu 操作系统+CPU的组合相关的代码 │ └─share 平台无关的共通代码 │ ├─tools 工具 │ │ ├─hsdis 反汇编插件 │ │ ├─IdealGraphVisualizer 将server编译器的中间代码可视化的工具 │ │ ├─launcher 启动程序“java” │ │ ├─LogCompilation 将-XX:+LogCompilation输出的日志(hotspot.log)整理成更容易阅读的格式的工具 │ │ └─ProjectCreator 生成Visual Studio的project文件的工具 │ └─vm HotSpot VM的核心代码 │ ├─adlc 平台描述文件(上面的cpu或os_cpu里的*.ad文件)的编译器 │ ├─asm 汇编器接口 │ ├─c1 client编译器(又称“C1”) │ ├─ci 动态编译器的公共服务/从动态编译器到VM的接口 │ ├─classfile 类文件的处理(包括类加载和系统符号表等) │ ├─code 动态生成的代码的管理 │ ├─compiler 从VM调用动态编译器的接口 │ ├─gc_implementation GC的实现 │ │ ├─concurrentMarkSweep Concurrent Mark Sweep GC的实现 │ │ ├─g1 Garbage-First GC的实现(不使用老的分代式GC框架) │ │ ├─parallelScavenge ParallelScavenge GC的实现(server VM默认,不使用老的分代式GC框架) │ │ ├─parNew ParNew GC的实现 │ │ └─shared GC的共通实现 │ ├─gc_interface GC的接口 │ ├─interpreter 解释器,包括“模板解释器”(官方版在用)和“C++解释器”(官方版不在用) │ ├─libadt 一些抽象数据结构 │ ├─memory 内存管理相关(老的分代式GC框架也在这里) │ ├─oops HotSpot VM的对象系统的实现 │ ├─opto server编译器(又称“C2”或“Opto”) │ ├─prims HotSpot VM的对外接口,包括部分标准库的native部分和JVMTI实现 │ ├─runtime 运行时支持库(包括线程管理、编译器调度、锁、反射等) │ ├─services 主要是用来支持JMX之类的管理功能的接口 │ ├─shark 基于LLVM的JIT编译器(官方版里没有使用) │ └─utilities 一些基本的工具类 └─test 单元测试 你看到的目录结构应该是类似这样的 |
|
woosheep
2011-08-06
RednaxelaFX 写道 不是“架构”不一样,是目录结构不一样。
如果你下的只是HotSpot VM的代码的话那好办,Oracle JDK 6/Oracle JDK 7/OpenJDK 6/OpenJDK 7里的HotSpot VM基本上目录结构都是一样的。 ├─agent Serviceability Agent的实现 ├─make 用来build出HotSpot的各种配置文件 ├─src HotSpot VM的源代码 │ ├─cpu CPU相关代码 │ ├─os 操作系相关代码 │ ├─os_cpu 操作系统+CPU的组合相关的代码 │ └─share 平台无关的共通代码 │ ├─tools 工具 │ │ ├─hsdis 反汇编插件 │ │ ├─IdealGraphVisualizer 将server编译器的中间代码可视化的工具 │ │ ├─launcher 启动程序“java” │ │ ├─LogCompilation 将-XX:+LogCompilation输出的日志(hotspot.log)整理成更容易阅读的格式的工具 │ │ └─ProjectCreator 生成Visual Studio的project文件的工具 │ └─vm HotSpot VM的核心代码 │ ├─adlc 平台描述文件(上面的cpu或os_cpu里的*.ad文件)的编译器 │ ├─asm 汇编器接口 │ ├─c1 client编译器 │ ├─ci 动态编译器的公共服务/接口 │ ├─classfile 类文件的处理(包括类加载和系统符号表等) │ ├─code 动态生成的代码的管理 │ ├─compiler 编译器接口 │ ├─gc_implementation GC的实现 │ │ ├─concurrentMarkSweep Concurrent Mark Sweep GC的实现 │ │ ├─g1 Garbage-First GC的实现(不使用老的分代式GC框架) │ │ ├─parallelScavenge ParallelScavenge GC的实现(server VM默认,不使用老的分代式GC框架) │ │ ├─parNew ParNew GC的实现 │ │ └─shared GC的共通实现 │ ├─gc_interface GC的接口 │ ├─interpreter 解释器,包括“模板解释器”(官方版在用)和“C++解释器”(官方版不在用) │ ├─libadt 一些抽象数据结构 │ ├─memory 内存管理相关(老的分代式GC框架也在这里) │ ├─oops HotSpot VM的对象系统的实现 │ ├─opto server编译器 │ ├─prims HotSpot VM的对外接口,包括部分标准库的native部分和JVMTI实现 │ ├─runtime 运行时支持库(包括线程管理、编译器调度、锁、反射等) │ ├─services 主要是用来支持JMX之类的管理功能的接口 │ ├─shark 基于LLVM的JIT编译器(官方版里没有使用) │ └─utilities 一些基本的工具类 └─test 单元测试 你看到的目录结构应该是类似这样的 woo~ 谢谢 这正是我想要的 谢谢谢谢~ 贪心地多问一句 不知道这在哪有得查呢?有没有具体到每个文件,甚至每个函数的说明? |
|
RednaxelaFX
2011-08-06
我是没找到过…上面是自己总结的,如果有不对的地方请谅解,如果能反馈更好
这代码有很多东西看名字就大概能猜到是干什么的了。要是预先有足够背景知识的话会更容易猜中吧。 |
|
hellhell
2011-08-06
HotSpot是一个巨大的焦油坑,只见过RednaxelaFX这样的天才少年,可以钻研如此之深。
|
|
woosheep
2011-08-06
RednaxelaFX 写道 我是没找到过…上面是自己总结的,如果有不对的地方请谅解,如果能反馈更好
这代码有很多东西看名字就大概能猜到是干什么的了。要是预先有足够背景知识的话会更容易猜中吧。 那真是太感谢了 以后多向您请教 |
|
richard_2010
2011-08-08
hellhell 写道 HotSpot是一个巨大的焦油坑,只见过RednaxelaFX这样的天才少年,可以钻研如此之深。
同意,我觉得在国内精读jvm源码的没几个 |
|
beneo
2011-08-12
richard_2010 写道 hellhell 写道 HotSpot是一个巨大的焦油坑,只见过RednaxelaFX这样的天才少年,可以钻研如此之深。
同意,我觉得在国内精读jvm源码的没几个 RednaxelaFX 搞JVM,搞GC可能要10年+,我们可是百年起 |