【exception】androidコンパイルANTパッケージ異常java.lang.OutOfMemoryError: GC overhead limit exceeded

2662 ワード

UNEXPECTED TOP-LEVEL ERROR:
java.lang.OutOfMemoryError: GC overhead limit exceeded
    at com.android.dx.dex.code.OutputFinisher.findExpandedOpcodeForInsn(OutputFinisher.java:525)
    at com.android.dx.dex.code.OutputFinisher.calculateReservedCount(OutputFinisher.java:466)
    at com.android.dx.dex.code.OutputFinisher.reserveRegisters(OutputFinisher.java:402)
    at com.android.dx.dex.code.OutputFinisher.finishProcessingAndGetList(OutputFinisher.java:358)
    at com.android.dx.dex.code.DalvCode.finishProcessingIfNecessary(DalvCode.java:108)
    at com.android.dx.dex.code.DalvCode.getInsns(DalvCode.java:185)
    at com.android.dx.dex.file.CodeItem.place0(CodeItem.java:223)
    at com.android.dx.dex.file.OffsettedItem.place(OffsettedItem.java:242)
    at com.android.dx.dex.file.MixedItemSection.placeItems(MixedItemSection.java:312)
    at com.android.dx.dex.file.DexFile.toDex0(DexFile.java:543)
    at com.android.dx.dex.file.DexFile.toDex(DexFile.java:216)
    at com.android.dx.command.dexer.Main.writeDex(Main.java:574)
    at com.android.dx.command.dexer.Main.run(Main.java:218)
    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

 
 
解決方法:
方法1:
Javaコマンドでjava仮想マシンスタックのサイズを指定して、コンパイルする必要があるものを先にコンパイルします.数分かかるかもしれません.
 
      java -Xms3550M -Xmx3550M -jar/home/test/4.0/out/host/linux-x86/framework/dx.jar --dex --output=out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/noproguard.classes-with-local.dex --core-library out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/noproguard.classes.jar
これを実行した後.またmakeをやり直せばいいのですが、このパッケージはmakeに出てきたので、makeをやり直すときはコンパイルしません
この方法はmakeエラー後に上記のコマンドを実行し、次にmakeコマンドを実行するしかありません.
 
方法2:
修正mkファイルbuild/core/ディレクトリの下にあるファイル
変数の変更:transform-classes.JAr-to-dexの-JXms 16 M-JXmx 1024 M値
コード内の変数定義:
define transform-classes.jar-to-dex @echo "target Dex: $(PRIVATE_MODULE)"@mkdir -p $(dir $@) $(hide) $(DX)\    $(if $(findstring windows,$(HOST_OS)),,-JXms16M -JXmx1024M)\    --dex --output=$@\    $(if $(NO_OPTIMIZE_DX),\        --no-optimize)\    $(if $(GENERATE_DEX_DEBUG),\        --debug --verbose\        --dump-to=$(@:.dex=.lst)\        --dump-width=1000)\    $(PRIVATE_DX_FLAGS)\    $< endef
-JXms 16 M-JXmx 1024 Mを適切な値に変更
私の機械はメモリが32 Gで、私は-JXms 16 M-JXmx 1024 Mを-JXms 1024 M-JXmx 2048 Mに修正します
具体的な値の大きさは、特定のマシンのメモリによって異なります.メモリが少なすぎて設定された値が大きいと、問題が発生します.