android JVM GC overhead limit exceeded

最近在项目中经常出现Caused by: java.lang.OutOfMemoryError: GC overhead limit exceeded
的error,是由于并行/并发回收器在GC回收时间过长时会抛出OutOfMemroyError。过长的定义是,超过98%的时间用来做GC并且回收了不到2%的堆内存。用来避免内存过小造成应用不能正常工作。解决此问题两个方向:
1,检查代码,检查内存泄漏,特别是隐藏比较深的内存泄漏,比如引入的第三方的SDK。由于每个人的代码各异,不好定位,这个方向就不讨论。
2,GC时间太长,堆太小,没有足够的内存,那么就增大堆的大小最为直接,在android studio的gradle properties配置如下信息即可:

org.gradle.daemon=true
org.gradle.jvmargs=-Xmx4096m -XX:MaxPermSize=4096m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
org.gradle.parallel=true
org.gradle.configureondemand=true

我这里是将JVM的堆空间设置成4G了,这个可以根据你的实际情况而定。

猜你喜欢

转载自blog.csdn.net/weixin_42042620/article/details/89448551