JVM是什么?
JVM是Java虚拟机,是能够运行Java程序的软件,为Java语言实现跨平台提供主要保障,它能够解释并执行Java字节码(.class)文件。
JVM的产品需求
功能性需求
- 能够加载字节码文件到内存中。
- 能够校验CLass文件结构并识别其合法性。
- 需要提供内存储存Class文件信息。
- 需要提供存储对象以及执行计算的内存。
- 需要提供执行引擎可以解释Class文件信息。
- 需要提供垃圾回收器对象对内存进行回收。
- 可以与第三方的语言进行通讯。
非功能需求
- 性能需求(包括:读取类的效率、创建对象的效率、解释字节码的效率、GC的效率)
- 可用性
- 可移植性
- 安全性
- 可扩展性
产品架构设计
- 类加载子系统
- 运行时数据区
- 程序执行引擎
- 本地库接口
类加载子系统
- 负责查找类
- 负责加载类到内存(线程、I/O)
- 负责校验类的信息(语法)
- 负责对类进行初始化(类变量赋值、执行静态代码块)
运行时数据区
- 栈区(负责存储要调用的方法信息、执行表达式的计算)
- 程序计数器(负责记录执行引擎要执行的下一条指令、每个线程都有一个计数器)
- 方法区(负责存储类字节码信息、提供一些常量池)
- 堆(负责存储对象)
程序执行引擎
- 解释器(负责解释class信息,转换成机器码)
- 垃圾回收期(对内存中的垃圾进行回收整理)
本地库接口
- 负责与操作系统进行通讯(使用C、C++)
落地产品
- HotSpot 甲骨文公司
- JRockit BEA公司
- J9 IBM公司
- TaoBaoVM 阿里
- Kona Tecent
产品落地关键技术
- 编程语言
- 多线程并发
- I/O、NI/O应用
- 网络通讯
- 设计模式