JDK 9即将给我们带来jigsaw module系统, 其中最大的变化(对我来说)就是java即将使用新的image文件,而不再使用jar这种文件格式打包。为什么?原因如下
1. 首先jar是一个非常老的协议,它是基于很老的zip协议,效率上比较差,空间占用也比较大。
2. jar是基于文件系统而不是基于module的,也就是说jar打包的原则是把某几个目录下的文件打成一个包;而jigsaw给我们带来了模块化的概念,我们希望有一种新的文件格式支持模块化而不是目录结构。
3. 我们需要一种可以通过模块直接load class的方式。
4. 一种可以扩充的支持附加信息的文件结构,比如预计算的java虚拟机的数据结构和预编译的本地代码。(这点对于预编译JIT很有帮助)
5. 提供一种遍历模块化classes的功能,现阶段只能通过jar去解析jar文件。
6. 在jre和jdk建立起一个边界,使得实现和接口分离,修改实现将不用修改接口(jdk经常会因为修正bug或者更改内部实现被修改,而jre里面都是稳定的类和接口,通常不怎么需要修改)
7. 加强java安全性,这样可以选择性的对某些类执行do-privileging。(现阶段通常是对所有的类做do-privileging)。