深入理解java虚拟机——如何下载hotspot、jdk源码

目录

 

 

为什么要学习jvm

如何下载jdk源码、hotspot源码

Hotspot的目录结构 


 

为什么要学习jvm


学习JVM对于一个Java程序员的好处大概可以概括为下8点:

  1. 了解java的发展历程,以及计算机语言的历史发展进程。
  2. 垃圾回收算法与原理 
  3. 类字节码规范与执行引擎 
  4. 内存模型与线程 
  5. 类加载机制
  6. 编译器
  7. 高效并发,线程安全与锁优化
  8. 性能监控以及jvm调优

可以从java语言运行的底层来了解java的运行原理

首先我们看一下

 

如何下载jdk源码、hotspot源码

1. 进入网址:,这个网http://hg.openjdk.java.net址下面列出了所有开源的openjdk项目,从中我们可以看到jdk项目。

 

 

2. jdk8u为例说明

红框标注的就是我们需要下载的hotspot、jdk源码:

 

 

 

3.以hotspot为例,进入如下页面,我们在点击browse, 就可以看到源码的目录结构了:

 

 

4. 最后点击zip,就可以下载源码的压缩包了,下载jdk的方式同上

 

 

下载完毕后hotspot的文件目录大致如下:

Hotspot的目录结构 

Hotspot的目录结构


├─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                             单元测试

 

后面我们会针对里面的内容做详细的讲解学习。

希望可以和大家一起探讨学习,共同提升知识技能。

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章