为什么有full GC还会发生oom(OutOfMemoryError)

JVM 有fullGC为什么还会出现oom(OutOfMemoryError)?

既然在触发full gc的时候,年老代和持久代都会被清理,那么为什么还会出现oom问题?

而且对于强引用,当内存空间不足,java虚拟机宁愿抛出oom错误,使程序异常终止,也不会靠随意回收具有强引用的对象来解决内存不足问题;

那么full gc机制的存在有何意义?
还是说fgc主要针对的是驻扎在老年的的软引用? 既然如此,对于四种引用的方式如何抉择?总不能所有对象都创建引用队列使用软引用或弱引用吧?

举个栗子:
为什么我请了佣人来收拾房间,我的房间还是会堆满?那我还请佣人来干什么?

他不是号称能把我房间里的垃圾都清理干净么?

问题是如果你房间里堆得都是宝贝(或者看起来都是宝贝)的话,佣人也没辙。

怎么判断是不是宝贝呢?
就看主人有没有用手抓着他它—被抓住的宝贝如果有连接到别的宝贝的话那被连接到的也算上。

用例抓住的肯定是宝贝,一点没碰的肯定不是宝贝,半抓不抓着的先观望。

总结:
full gc收集的是垃圾,及不可用的东西,如果对内存中的对象大部分是可达的,而此时又有新的对象需要分配内存空间,如果此时可用空间不够就会OOM。

还有一个简单的例子,你的堆只有100M,你new了一个101M的大数组,GC再牛逼也没用

你可能感兴趣的:(java,jvm)