(三)JVM的内存模型

内存区域

JVM运行过程中,会划分为不同的内存区域来存放不同的数据。

1.方法区。类加载进来后,必须有一块内存区域来存放这类数据,就是”方法区“。JDK1.8后,这块区域改成了”Metaspace“,是分配在堆外内存的。

2.程序计数器。我们写好的代码会被编译成字节码,对应着各种字节码指令,这些指令由字节码执行引擎来执行。用”程序计数器“来记录当前执行到了哪一条字节码指令。JVM支持多线程,每个线程都会并发执行不同的代码,因此每个线程都会有自己的一个程序计数器。

3.Java虚拟机栈。每个线程都会由自己的Java虚拟机栈,用来存放局部变量、操作数栈、方法出口等相关信息。每当调用一个方法时,就会给对应的线程的栈创建并压入一个栈帧。当方法执行完毕后,所对应的栈帧会从栈中出栈。

4.本地方法栈。跟Java虚拟机栈类似,只不过它调用的时操作系统的本地native方法。

5.堆。存放在代码中创建的各种对象。

6.直接内存。这块内存区域不属于JVM的,通过NIO的allocateDirect在Java堆外分配内存空间。可以通过JVM的DirectByteBuffer来引用和操作堆外内存空间。会在一些场景使用堆外内存,因为可以提升性能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值