手写商用Java虚拟机HotSpot,疯狂磨砺技术中
在当前Java行业激烈竞争的形式下,唯有掌握技术,心中才不能慌。在多年前,我就开始苦练底层技术,但是眼看百遍也不如手过一遍,所以我打算把虚拟机的精华实现部分用手敲出来,这个过程注定不会轻松,但是心态不能着急,要一步一步来,一年二年三年后终能达成。
这个过程还会录制一些免费视频,简单介绍一下这个视频适合的目标人群,达到的目的等。
1、目标人群
对虚拟机底层实现有浓厚兴趣的人
想提升Java技术,精通Java语言的人
想切入虚拟机和编译器领域研发的人
想通过大型复杂的项目提升C++水平的人
不过HotSpot VM项目太过复杂,对C++、Linux系统编程、汇编指令、机器指令、编译原理等各方面都有较高的要求,如果这些方面的基础比较弱的话,还需要多加强。
2、达到的目的
精通Java的底层实现
对虚拟机的性能调优和故障排查得心应手
能够对虚拟机整体的实现有一个清晰的认识,达到动手开发虚拟机的能力
对后续研究更为复杂的C2编译器和G1等垃圾收集器有非常大的帮助
熟练使用C++
熟练掌握汇编语言
当研究lua、python等虚拟机时会感到更简单,研究v8等时感觉代码许多都很熟悉,很类似
另外,开课也会让许多人坚持下来,毕竟有人引路,也能节省非常多的时间和精力
3、编译调试环境
Linux(Ubuntu 16.04)
CPU架构为X86,位数为64
版本仅支持JDK1.8(也就是向前兼容的代码全部省略)
Linux内核版本 4.4.0-210-generic
GNU 5.4.0版本的编译器
编辑器:Visual Studio Code1 .51.0
使用语言:主体为C++语言,少量汇编有C语言
4、功能说明
商用HotSpot VM手写内容时,由于整个工程的代码在50万行左右,其中95%以上都是C++。我们只实现其实的精华部分即可,所以许多功能都不会实现。
不实现的功能如下:
(1)只实现C1编译器,不实现C2编译器
(2)没有指针压缩版实现
(3)堆不支持大页
(4)字节码解释器不再手写实现(PC上的效率太低,不适合生产用,但是会详细介绍)
(5)只包含Serial/Serial Old收集器,后期会实现G1,不实现Parallel和CMS等收集器
(6)不对类加载过程中的类进行合法性验证,也就是没有验证阶段
(7)不实现偏向锁和轻量级锁,直接使用重量级锁,会详细介绍偏向锁和轻量级锁
(8)线程采用NPTL 2.23版本,不兼容LinuxThreads
(9)不对一些统计做实现,如写PerfData, NMT等功能,记录GC日志等
(10)不实现SharedCDS
(11)省略SecurityManager和Protected Domain,类型安全检查约束
(12)不实现调试信息记录
(13)FlatProfiler不实现
(14)不实现一些实验性质的逻辑
(15)可省略的一些验证逻辑,如验证AdapterBlob的正确性,加上-XX:-VerifyAdapterCalls命令省略
(16)不对一些支持Java层Deprecated方法的功能进行实现,如线程的suspend和resume
(17)对默认选项为false的逻辑不实现,如UseNUMA等
(18)JNI和JVMTI选择性实现
(19)不实现vmStructs,不支持 SA(Serviceability Agent)
(20)不实现JMX、Attach及内部一些命令,如dumpheap、threaddump、jcmd及load等
当然,后续还有非常多需要补充和完善的地方,请持续关注...
5、实现路径:
大模块的实现路径如下:
内部锁
线程
二分模型
类的加载和解析
堆的简单规划
元数据区
CodeCache
模板解释器解释执行
Serial和Serial Old垃圾收集器
C1编译器
由于各个模块都是耦合紧密,相互交错,所以具体编写时会是一个循序渐进,逐步完善的过程。不会是一个模块写完再另外一个模块,需要以基本面完善点这样一个过程。
6、后续计划
在B站上免费更新一部分视频,后续有收费开课的打算。免费课程大纲如下:

手写Java虚拟机HotSpot终于要录制一系列视频啦!
有对虚拟机、Java性能故障诊断与调优等感兴趣的人可以入群讨论。

手写商用Java虚拟机HotSpot,疯狂磨砺技术中的更多相关文章
- 如何写出让java虚拟机发生内存溢出异常OutOfMemoryError的代码
程序小白在写代码的过程中,经常会不经意间写出发生内存溢出异常的代码.很多时候这类异常如何产生的都傻傻弄不清楚,如果能故意写出让jvm发生内存溢出的代码,有时候看来也并非一件容易的事.最近通过学习< ...
- 手写实现java栈结构,并实现简易的计算器(基于后缀算法)
一.定义 栈是一种线性表结构,栈结构中有两端,对栈的操作都是对栈的一端进行操作的,那么被操作的一端称为栈顶,另一端则为栈底.对栈的操作其实就是只有两种,分别是入栈(也称为压栈)和出栈(也称为弹栈).入 ...
- 深入理解Java虚拟机-HotSpot虚拟机对象探秘
一.对象的创建过程 虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初始化过.如果没有,那就先执行相应的类 ...
- 手写一个Java程序输出HelloWorld
` 创建一个Hello.java文件使用记事本打开 public class Hello{ public static void main(String [] args){ System.out.pr ...
- 深入浅出解读 Java 虚拟机的差别测试技术
本文分享基于字节码种子生成有效.可执行的字节码文件变种,并用于 JVM 实现的差别测试.本文特别提出用于修改字节码语法的classfuzz技术和修改字节码语义的classming技术.上述变种技术系统 ...
- 深入理解多线程(五)—— Java虚拟机的锁优化技术
本文是<深入理解多线程>的第五篇文章,前面几篇文章中我们从synchronized的实现原理开始,一直介绍到了Monitor的实现原理. 前情提要 通过前面几篇文章,我们已经知道: 1.同 ...
- JAVA虚拟机03-常量池项中字面量和符号引用
转https://baijiahao.baidu.com/s?id=1682261792528500739&wfr=spider&for=pc 1 符号引用 符号引用以一组符号来描述所 ...
- 爬虫入门 手写一个Java爬虫
本文内容 涞源于 罗刚 老师的 书籍 << 自己动手写网络爬虫一书 >> ; 本文将介绍 1: 网络爬虫的是做什么的? 2: 手动写一个简单的网络爬虫; 1: 网络爬虫是做 ...
- 手写代码 - java.util.Arrays 相关
1-拷贝一个范围内的数组 Arrays.copyOfRange( array, startIndex, endIndex); include startIndex... exclude endInde ...
- 手写代码 - java.lang.String/StringBuilder 相关
语言:Java 9-截取某个区间的string /** * Returns a string that is a substring of this string. The * substring b ...
随机推荐
- CF1829H Don't Blame Me题解
题意: 给定一个长度为 \(n\) 的数组,选择它的一个子序列(不一定要连续的),问有多少种选法使得它们 AND 的值的二进制表示法中有 \(k\) 个 \(1\). 思路: 这个题就是一个简单的 D ...
- Code Generate V2.0 代码生成器
Code Generate 代码生成器 系统首页 使用说明 系统默认会根据SQL生成字段信息 className.fieldList.classComment 如下所示: 建表语句 CREATE TA ...
- Codeforces Round #882 (Div. 2) A-D
比赛链接 A 代码 #include <bits/stdc++.h> using namespace std; using ll = long long; int a[107]; int ...
- C语言指针--指针中的const
文章目录 前言 一.const 1.什么是const 2.const的使用 二.const修饰一级指针 1.const放在 `*` 左边 2.const在`*`右边 三.const修饰二级指针 1.c ...
- C++(类成员的访问控制)
访问控制 如下代码,Student这个类的所有成员我们都可以调用,但是我们不想让被人调用Print1这个方法该怎么? struct Student { int age; int sex; void P ...
- Linux 命令:time
参考链接: time 命令
- SPI总线学习笔记
SPI是串行外设接口(Serial Peripheral Interface)的缩写,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空 ...
- 2021-11-30 wpf的mvvm绑定2
主页页面代码 <Grid> <TextBox x:Name="First" Width="80" Height="20" ...
- Python实现输入三个整数x,y,z,请把这三个数由小到大输出;
num1=input('请输入第一个数,x:') num2=input('请输入第二个数,y:') num3=input('请输入第三个数,z:') if num1>num2: # if 语句判 ...
- 文心一言 VS 讯飞星火 VS chatgpt (74)-- 算法导论7.2 2题
二.如果用go语言,当数组A的所有元素都具有相同值时,QUICKSORT的时间复杂度是什么? 文心一言: 在Go语言中,对一个所有元素都相等的数组进行快速排序(QuickSort)的时间复杂度是O(n ...