郭朝 2020-05-15
JVM内存主要分为三部分线程私有(Thread Local)、线程共享(Thread Shared)、直接内存(Direct Memory)。
线程私有区域从字面意思可以看出,这部分内存,是归属于每个线程独立拥有的部分。其生命周期与线程生命周期一致。线程私有区域可以分为两部分程序计速器、虚拟机栈和本地方法栈。
注意
局部变量表所需要的内存空间在编译期完成分配,当进入一个方法时,这个方法在栈中需要分配多大的局部变量空间是完全确定的,在方法运行期间不会改变局部变量表大小。
本地方法栈和虚拟机栈作用类似,虚拟机栈执行的是Java方法(也就是字节码),而本地方法栈则为虚拟机使用到的 Native 方法服务,可能底层调用的 C 或者 C++,我们打开 JDK 安装目录可以看到也有很多用 C 编写的文件,可能就是 Native 方法所调用的 C 代码。
线程共享区域随虚拟机的启动而创建,随虚拟机的关闭而销毁。
方法区即我们常说的永久代(Permanent Generation),用于存储已被虚拟机加载的类信息、常量、静态变量,如 static 修饰的变量加载类的时候就被加载到方法区中。
运行时常量池
是方法区的一部分,Class文件除了有类的字段、接口、方法等描述信息之外,还有常量池用于存放编译期间生成的各种字面量和符号引用。
直接内存并不是 JVM 运行时数据区的一部分,但也会被频繁的使用(在NIO中,可以使用 Native 函数库直接分配堆外内存,然后使用 DirectByteBuffer 对象作为这块内存的引用进行操作,避免了在 Java 堆和 Native 堆中来回复制数据, 因此在一些场景中可以显著提高性能)。