1.1 概述
Java不止是一门编程语言,它是一些列计算机软件和规范所形成的技术体系。
1.2 技术体系
Sun官方定义Java技术体系由5各部分组成,如下:
- Java编程语言
- JVM
- Class文件格式
- Java API 类库
- 第三方Java类库(商业或开源)
其中 「Java编程语言」、「JVM」、「Java API类库」统称为JDK(Java Development Kit),即Java程序开发最小环境。
其中「JVM」、「Java API的SE子集」统称为JRE(Java Runtime Environment),即Java程序运行的标准环境。
通过所关注的业务领域不同,我们也可以将Java技术体系进行如下划分:
- Java Card
针对小内存的设备,例如:存储卡 - Java ME
简称J2ME,针对移动设备,例如:手机、PAD - Java SE
简称J2SE,桌面应用的开发 - Java EE
简称J2SE,企业应用
1.3 JVM发展史
- Sun Classic VM
- JDK1.0 所带的虚拟机
- 纯解释执行
- 要想使用即时编译器(JIT)必须以外挂的方式
- 及时编译器不能与解释器协同使用,也就是使用了及时编译器就无法同时使用解释器了,这样的话就会带来一个问题,无论代码是否有编译价值即时编译器(JIT)都要进行编译。
- Sun Exact VM
- 采用了准确式的内存管理,虚拟机知道每个内存位置上的数据是什么类型,借此GC就可以判断堆上的数据哪些还能使用。
- 由于采用了准确式内存管理,Exact VM抛弃了Classic VM基于handler来定位对象的方式,这样的好处是,减少一次间接查询,提高了执行的性能。
- Sun HotSpot VM
- Sun JDK和OpenJDK中的虚拟机
- 热点代码探测就是通过执行计数器来选出具有编译价值的代码,然后将编译请求提交给编译器,编译器以方法为单位进行编译。
- 如果方法的执行频率高,则触发标准的JIT编译操作。如果是方法内循环的次数很多,则触发OSR(栈上替换)的编译操作。
- JRockit VM
- BEA 推出的虚拟机
- J9
- IBM 推出的虚拟机
1.4 展望Java技术的未来
- 多核并行
fork/join是处理并行编程的经典方法,示意图如下:
下一篇:《深入理解JAVA虚拟机(第2版)》- 第2章 - 学习笔记