内存区域
JVM运行过程中,会划分为不同的内存区域来存放不同的数据。
1.方法区。类加载进来后,必须有一块内存区域来存放这类数据,就是”方法区“。JDK1.8后,这块区域改成了”Metaspace“,是分配在堆外内存的。
2.程序计数器。我们写好的代码会被编译成字节码,对应着各种字节码指令,这些指令由字节码执行引擎来执行。用”程序计数器“来记录当前执行到了哪一条字节码指令。JVM支持多线程,每个线程都会并发执行不同的代码,因此每个线程都会有自己的一个程序计数器。
3.Java虚拟机栈。每个线程都会由自己的Java虚拟机栈,用来存放局部变量、操作数栈、方法出口等相关信息。每当调用一个方法时,就会给对应的线程的栈创建并压入一个栈帧。当方法执行完毕后,所对应的栈帧会从栈中出栈。
4.本地方法栈。跟Java虚拟机栈类似,只不过它调用的时操作系统的本地native方法。
5.堆。存放在代码中创建的各种对象。
6.直接内存。这块内存区域不属于JVM的,通过NIO的allocateDirect在Java堆外分配内存空间。可以通过JVM的DirectByteBuffer来引用和操作堆外内存空间。会在一些场景使用堆外内存,因为可以提升性能。