GC overhead limit exceeded 分析
官方定义的解释:当JVM花费超过98%的时间用来做GC(垃圾回收)并且只回收了不到2%的堆内存时,会抛出此异常。
通俗点说,其实就是我们的程序几乎把所有的内存都用完了,而GC花了很多时间去清理内存垃圾,但是清理的效率很低,导致内存不够用了,所以就会发生此异常。
解决方案
1. 增大堆内存
2. 优化代码
其实增大堆内存是一种治标不治本的方法,只能说目前解决了问题。
我们应该找出抛出此异常的根本原因,所以我们就需要去检查程序中是否存在 死循环 或者 大量消耗内存 的代码,优化这一部分的代码。