jdk源码解析(一)
来源:互联网 发布:南京魔苹网络能去吗 编辑:程序博客网 时间:2024/06/14 06:36
1、先说一下源码解析的过程:JDK-->JRE-->JVM(以openJDK代替)
注意:这里要了解jdk和jre和jvm他们分别是什么?以及他们的关系才可以继续。这里先上一章从网上下载的关系图方便理解
2、笔者本地的jdk是oraclejdk,jvm所在位置就是安装的jdk。jdk下jre下bin下server下的jvm.dll。也就是F:\Java\jdk\jdk1.7.0_60\jre\bin\server这里的jvm.dll。因为jvm.dll不能看,所以这里以下载的openjdk源码作为解析(openjdk-7u40-fcs-src-b43-26_aug_2013.zip)。
3、openjdk源码目录结构这里上图:
解释:
openjdk
—— corba:不流行的多语言、分布式通讯接口
—— hotspot:Java 虚拟机
—— jaxp:XML 处理
—— jaxws:一组 XML web services 的 Java API
—— jdk:java 开发工具包
—— —— 针对操作系统的部分
—— —— share:与平台无关的实现
—— langtools:Java 语言工具
—— nashorn:JVM 上的 JavaScript 运行时
4、因为要了解jvm虚拟机。所以进入hotspot目录下
其中Hotspot就是我们要看的JVM包
Hotspot:全称 Java HotSpot Performance Engine,是 Java 虚拟机的一个实现,包含了服务器版和桌面应用程序版。利用 JIT 及自适应优化技术(自动查找性能热点并进行动态优化)来提高性能。
使用java -version
可以查看 Hotspot 的版本。[machao@dev ~]$ java -versionopenjdk version "1.8.0_144"OpenJDK Runtime Environment (build 1.8.0_144-b01)OpenJDK 64-Bit Server VM (build 25.144-b01, mixed mode)[machao@dev ~]$OpenJDK 64-Bit Server VM (build 25.144-b01, mixed mode)就是版本。
所以:我们详解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 单元测试
具体了解先将到这里。
- jdk源码解析(一)
- jdk源码解析(二)
- JDK动态代理(源码解析)
- JDK核心JAVA源码解析(1)
- ConcurrentHashMap源码解析(JDK 1.8)
- JDK DualPivotQuicksort 源码解析
- JDK DualPivotQuicksort 源码解析
- JDK DualPivotQuicksort 源码解析
- JDK DualPivotQuicksort 源码解析
- jdk源码解析--set
- JDK源码(一)Object类
- JDK源码(一)HashSet、HashMap、Hashtable
- JDK日志框架源码分析(一)
- JDK源码分析之ArrayList(一)
- 【集合源码】HashMap源码解析(基于JDK 1.8)
- jdk 源码分析(15)java CountDownLatch 源码解析
- jdk 源码分析(16)java CyclicBarrier 源码解析
- 【JDk源码解析之一】ArrayList源码解析
- POJ 2777-Count Color-(线段树)
- jdbc与线程安全
- 如何估算剩余的bug数量
- 第5周项目2- 建立链栈算法库
- 使用 CXF 做 webservice 简单例子
- jdk源码解析(一)
- [LCT] BZOJ2759.一个动态树好题
- leetcode: 653. Two Sum IV
- Maven 项目管理工具
- Android中的SP、DP等的关系和概念
- python中的while语句
- 共现分析
- 算法练习(10):Merge k Sorted Lists
- 多线程