JVM-运行时数据区

JVM-运行时数据区
线程私有:程序计数器、虚拟机栈、本地方法栈
共享区域:堆、方法区

Java堆

所有线程共享的一块内存区域,在虚拟机启动时创建。
此内存区域的唯一目的就是存放对象实例。
几乎所有的对象实例和数组都应当在堆上分配。

Java堆既可以被设计成固定大小的,也可以是可扩展的。(通过-Xmx、-Xms设定)。
JVM-运行时数据区

方法区

各个线程共享的内存区域。

运行时常量池是方法区的一部分。
Class文件中的一项信息——常量池表,用于存放编译期生成的各种字面量与符号引用,这部分内容将在类加载后存放在方法区的常量池中。
运行时常量池相对于Class文件的常量池表还有一个重要的特征——具备动态性,运行期间也可以将新的常量放入运行时常量池中(String类的intern方法)。

直接内存

JDK1.4中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)和缓冲区(Buffer)的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java堆和Native堆中来回复制数据。
JVM-运行时数据区

《深入理解Java虚拟机》第三版
https://blog.****.net/liaynling/article/details/81251870