为什么有Full GC还会发生OOM
既然在触发 full gc 的时候,年老代和持久代都会被清理,那么为什么还会出现 oom 问题?
而且对于强引用,当内存空间不足,java 虚拟机宁愿抛出 oom 错误,使程序异常终止,也不会靠随意回收具有强引用的对象来解决内存不足问题;
那么 full gc 机制的存在有何意义?
还是说 fgc 主要针对的是驻扎在老年的的软引用? 既然如此,对于四种引用的方式如何抉择?总不能所有对象都创建引用队列使用软引用或弱引用吧?
举个栗子:
为什么我请了佣人来收拾房间,我的房间还是会堆满?那我还请佣人来干什么?
他不是号称能把我房间里的垃圾都清理干净么?
问题是如果你房间里堆得都是宝贝(或者看起来都是宝贝)的话,佣人也没辙。
怎么判断是不是宝贝呢?
就看主人有没有用手抓着他它—被抓住的宝贝如果有连接到别的宝贝的话那被连接到的也算上。
用例抓住的肯定是宝贝,一点没碰的肯定不是宝贝,半抓不抓着的先观望。
总结:
full gc 收集的是垃圾,及不可用的东西,如果对内存中的对象大部分是可达的,而此时又有新的对象需要分配内存空间,如果此时可用空间不够就会 OOM。
还有一个简单的例子,你的堆只有 100M,你 new 了一个 101M 的大数组,GC 再牛逼也没用
为什么有Full GC还会发生OOM
http://example.com/2023/03/07/uo7p97db2v3fxubr/