Android ics 编译时GC overhead limit exceeded错误解决方法

本文提供了解决Android应用编译时出现的GC overhead limit exceeded错误的方法,通过调整编译器参数来提升内存使用效率,避免在8GB内存环境下出现的编译卡顿问题。

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

出错的log信息如下

UNEXPECTED TOP-LEVEL ERROR:
java.lang.OutOfMemoryError: GC overhead limit exceeded
	at com.android.dx.ssa.SsaBasicBlock.<init>(SsaBasicBlock.java:125)
	at com.android.dx.ssa.SsaMethod.makeNewGotoBlock(SsaMethod.java:240)
	at com.android.dx.ssa.SsaBasicBlock.insertNewSuccessor(SsaBasicBlock.java:454)
	at com.android.dx.ssa.SsaConverter.edgeSplitMoveExceptionsAndResults(SsaConverter.java:210)
	at com.android.dx.ssa.SsaConverter.edgeSplit(SsaConverter.java:136)
	at com.android.dx.ssa.SsaConverter.convertToSsaMethod(SsaConverter.java:48)
	at com.android.dx.ssa.Optimizer.optimize(Optimizer.java:99)
	at com.android.dx.ssa.Optimizer.optimize(Optimizer.java:73)
	at com.android.dx.dex.cf.CfTranslator.processMethods(CfTranslator.java:273)
	at com.android.dx.dex.cf.CfTranslator.translate0(CfTranslator.java:134)
	at com.android.dx.dex.cf.CfTranslator.translate(CfTranslator.java:87)
	at com.android.dx.command.dexer.Main.processClass(Main.java:483)
	at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455)
	at com.android.dx.command.dexer.Main.access$400(Main.java:67)
	at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394)
	at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245)
	at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131)
	at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109)
	at com.android.dx.command.dexer.Main.processOne(Main.java:418)
	at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329)
	at com.android.dx.command.dexer.Main.run(Main.java:206)
	at com.android.dx.command.dexer.Main.main(Main.java:174)
	at com.android.dx.command.Main.main(Main.java:95)
make: *** [out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/noproguard.classes-with-local.dex] Error 3

解决方法:

更改编译配置文件build/core/definitions.mk中的缓存参数:

define transform-classes.jar-to-dex
@echo "target Dex: $(PRIVATE_MODULE)"
@mkdir -p $(dir $@)
$(hide) $(DX) \
    $(if $(findstring windows,$(HOST_OS)),,-JXms16M -JXmx1536M) \
    --dex --output=$@ \
    $(incremental_dex) \
    $(if $(NO_OPTIMIZE_DX), \
        --no-optimize) \
    $(if $(GENERATE_DEX_DEBUG), \
   --debug --verbose \
   --dump-to=$(@:.dex=.lst) \
   --dump-width=1000) \
    $(PRIVATE_DX_FLAGS) \
    $<
endef

将红色标注部分的参数值更改为较大的值:-JXms1024M -JXmx1536M    (我的机器是8G内存),然后再次make,错误应该就不会再出现了。

不过参数的数值请根据自己的机器适当的改大,数值太大编译时会很卡。

Good luck to you~

### Java中解决GC Overhead Limit Exceeded错误的具体方法 `java.lang.OutOfMemoryError: GC overhead limit exceeded` 错误表明JVM在垃圾回收上花费了过多的时间(超过98%的CPU时间),但仅能回收少量内存(少于2%的堆空间)。以下是几种有效的解决方案: #### 1. **增加堆内存** 通过调整JVM参数来增大可用堆内存是一种常见的做法。可以通过以下命令设置最大堆大小和初始堆大小,并启用G1垃圾收集器: ```bash java -Xmx2048m -Xms1024m -XX:+UseG1GC YourApplication ``` 此操作可以缓解因堆内存不足而导致的频繁垃圾回收问题[^2]。 #### 2. **优化代码逻辑** - **检查内存泄漏** 需要特别关注静态集合类(如 `ArrayList`, `HashMap`)、缓存以及长时间存活的对象引用。如果这些对象未被正确释放,可能导致内存占用过高。 - **及时关闭资源** 数据库连接、文件流以及其他外部资源应始终在其使用完毕后立即关闭,避免不必要的内存消耗。 - **减少临时对象创建** 尤其是在循环体内,尽量避免创建大量的短生命周期对象。例如,在字符串拼接时优先使用 `StringBuilder` 而非简单的 `+` 运算符[^2]。 #### 3. **改进数据结构设计** 当涉及大规模数据处理时,选择合适的数据结构至关重要。例如,对于大容量的键值映射场景,默认构造函数可能引发性能瓶颈;因此建议显式指定哈希表的初始化容量及其负载因子以降低扩容频率: ```java Map<String, String> map = new HashMap<>(initialCapacity, loadFactor); ``` #### 4. **利用诊断工具分析内存状况** 为了深入理解应用程序的实际运行情况,可借助专门的调试工具完成进一步排查工作: - 使用 `jmap` 导出当前进程的堆转储快照并导入至第三方解析软件(比如 Eclipse MAT 或 VisualVM)进行可视化展示; ```bash jmap -dump:live,format=b,file=heap.bin <PID> ``` - 利用 JConsole 和 VisualVM 实现动态监测功能,观察各代区分布趋势变化规律以便定位潜在风险源[^2]。 #### 5. **调优垃圾回收算法配置** 除了默认采用 Parallel Scavenge 收集方式外,还可以尝试切换到其他更适合特定业务需求类型的清理模式,像 CMS (Concurrent Mark Sweep) 或者 G1 (Garbage First),具体实现如下所示: ```bash # 启动CMS并发标记清除收集器 java ... -XX:+UseConcMarkSweepGC ... # 开启G1垃圾收集器支持 java ... -XX:+UseG1GC ... ``` 以上措施能够显著改善由高比例垃圾回收所引起的异常现象发生概率,从而保障系统的稳定性和响应速度[^1][^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我叫特踏实

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值