图解JVM在内存中申请对象及垃圾回收流程

本文详细介绍了JVM内存模型的组成部分及其工作原理,包括永久代、堆内存、栈内存等,并给出了常见内存溢出问题的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载于作者longdick [url]http://longdick.iteye.com/blog/468368[/url]

先看一下JVM的内存模型:
[img]http://dl.iteye.com/upload/attachment/155163/2b5b5056-fda7-32b1-a7a7-d7f823947c90.png[/img]
从大的方面来讲,JVM的内存模型分为两大块:

永久区内存( Permanent space )和堆内存(heap space)。

栈内存(stack space)一般都不归在JVM内存模型中,因为栈内存属于线程级别。

每个线程都有个独立的栈内存空间。

Permanent space里存放加载的Class类级对象如class本身,method,field等等。

heap space主要存放对象实例和数组。

heap space由Old Generation和New Generation组成,Old Generation存放生命周期长久的实例对象,而新的对象实例一般放在New Generation。

New Generation还可以再分为Eden区(圣经中的伊甸园)、和Survivor区,新的对象实例总是首先放在Eden区,Survivor区作为Eden区和Old区的缓冲,可以向Old区转移活动的对象实例。

下图是JVM在内存空间(堆空间)中申请新对象过程的活动图(点击看大图):
[img]http://dl.iteye.com/upload/attachment/155165/29072aad-6845-347d-adc8-a09776e0a7d6.jpg[/img]

没错,我们常见的OOM(out of memory)内存溢出异常,就是堆内存空间不足以存放新对象实例时导致。

永久区内存溢出相对少见,一般是由于需要加载海量的Class数据,超过了非堆内存的容量导致。通常出现在Web应用刚刚启动时,因此Web应用推荐使用预加载机制,方便在部署时就发现并解决该问题。

栈内存也会溢出,但是更加少见。

堆内存优化:

调整JVM启动参数-Xms -Xmx -XX:newSize -XX:MaxNewSize,如调整初始堆内存和最大对内存 -Xms256M -Xmx512M。 或者调整初始New Generation的初始内存和最大内存 -XX:newSize=128M -XX:MaxNewSize=128M。

永久区内存优化:

调整PermSize参数 如 -XX:PermSize=256M -XX:MaxPermSize=512M。

栈内存优化:

调整每个线程的栈内存容量 如 -Xss2048K

最终,一个运行中的JVM所占的内存= 堆内存 + 永久区内存 + 所有线程所占的栈内存总和 。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值