JVM内存模型和调优

如上图三核处理器模型所示,堆内存和方法区线程共有,本地方法区、栈内存、程序计数器线程私有。

1.heap堆内存,存储实例对象,数组等资源,占用内存比例极大,内存的jvm会根据堆实际空闲比例自动调整所占内存大小,是GC的主要阵地。

2.mehod area方法区,各线程共享,存放类信息,常量,静态变量,编译后的代码等,jdk1.7及之前也称永久代,实际上永久代占用的内存空间很少,由GC负责清理,很容易导致内存溢出,即PermGen Space异常,所以在JDK1.8中,HotSpot VM取消了永久代,用元空间取而代之,元空间直接使用本地内存,理论上电脑有多少内存它就可以使用多少内存,所以不会再出现PermGen Space异常。

3.JVM Stack栈内存,当JVM在java执行方法时,会在此区域中创建一个栈帧来存放方法的各种信息,比如返回值,局部变量表和各种对象引用等,方法开始执行前就先创建栈帧入栈,执行完后就出栈。

4.Native Method Stack本地方法栈,为Native方法(加native关键字)服务,可以执行非java的语言方法。

5.PC Register程序计数器,来标识字节码文件的运行行数。

 

 

   

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值