android-maven-plugin вызывает java.lang.OutOfMemoryError при попытке создать dex - PullRequest
4 голосов
/ 09 февраля 2012

Мне нужна рука.Я использую android-maven-plugin 3.0.0 и maven-external-dependency-plugin 0.4 в проекте Android.Я использую эти библиотеки из разных репозиториев в качестве зависимостей:

<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.google.android</groupId>
        <artifactId>android</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>com.google.android</groupId>
        <artifactId>android-test</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency> 
        <groupId>com.admob.android.ads</groupId> 
        <artifactId>admob-android</artifactId> 
        <version>4.0.4</version> 
    </dependency>
    <dependency>
        <groupId>com.google.code</groupId>
        <artifactId>google-api-translate-java</artifactId>
        <version>0.97</version>
    </dependency>
    <dependency>
        <groupId>com.db4o</groupId>
        <artifactId>db4o-core-java5</artifactId>
        <version>${com.db4o.version}</version>
    </dependency>
    <dependency>
        <groupId>com.db4o</groupId>
        <artifactId>db4o-cs-java5</artifactId>
        <version>${com.db4o.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.james</groupId>
        <artifactId>apache-mime4j</artifactId>
        <version>0.6</version>
    </dependency>
    <dependency>
        <groupId>commons-codec</groupId>
        <artifactId>commons-codec</artifactId>
        <version>1.4</version>
    </dependency>
    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpmime</artifactId>
        <version>4.0.1</version>
    </dependency> 
    <dependency>
        <groupId>org.json</groupId>
        <artifactId>json</artifactId>
        <version>20090211</version>
    </dependency>
    <dependency>
        <groupId>org.restlet.jee</groupId>
        <artifactId>org.restlet</artifactId>
        <version>${restlet.version}</version>
    </dependency>
</dependencies>

Зависимости все удовлетворены, но когда приходит время вставить все банки в Android dex, я получаю ошибку нехватки памяти:

[INFO] UNEXPECTED TOP-LEVEL ERROR:
[INFO] java.lang.OutOfMemoryError: Java heap space
[INFO]  at com.android.dx.cf.code.OneLocalsArray.<init>(OneLocalsArray.java:46)
[INFO]  at com.android.dx.cf.code.OneLocalsArray.copy(OneLocalsArray.java:51)
[INFO]  at com.android.dx.cf.code.OneLocalsArray.copy(OneLocalsArray.java:33)
[INFO]  at com.android.dx.cf.code.Frame.copy(Frame.java:98)
[INFO]  at com.android.dx.cf.code.Ropper.processBlock(Ropper.java:683)
[INFO]  at com.android.dx.cf.code.Ropper.doit(Ropper.java:639)
[INFO]  at com.android.dx.cf.code.Ropper.convert(Ropper.java:252)
[INFO]  at com.android.dx.dex.cf.CfTranslator.processMethods(CfTranslator.java:256)
[INFO]  at com.android.dx.dex.cf.CfTranslator.translate0(CfTranslator.java:134)
[INFO]  at com.android.dx.dex.cf.CfTranslator.translate(CfTranslator.java:87)
[INFO]  at com.android.dx.command.dexer.Main.processClass(Main.java:483)
[INFO]  at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455)
[INFO]  at com.android.dx.command.dexer.Main.access$400(Main.java:67)
[INFO]  at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394)
[INFO]  at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245)
[INFO]  at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131)
[INFO]  at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109)
[INFO]  at com.android.dx.command.dexer.Main.processOne(Main.java:418)
[INFO]  at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329)
[INFO]  at com.android.dx.command.dexer.Main.run(Main.java:206)
[INFO]  at com.android.dx.command.dexer.Main.main(Main.java:174)
[INFO]  at com.android.dx.command.Main.main(Main.java:95)

Попытка увеличить память, добавив:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <configuration>
        <forkMode>pertest</forkMode>
        <argLine>-Xms1024m -Xmx2048m</argLine>
        <testFailureIgnore>false</testFailureIgnore>
        <skip>false</skip>
    </configuration>
</plugin>

или вот это:

<plugin>
    <groupId>com.jayway.maven.plugins.android.generation2</groupId>
    <artifactId>android-maven-plugin</artifactId>
    <inherited>true</inherited>
    <configuration>
        <argLine>-Xmx1024m</argLine>

...

или экспортируйте maven_opts, как это:1016 *

не решить проблему

Я получаю несколько предупреждений о том, что классы в зависимых файлах компилируются со старым форматом классов, но я не уверен, что это является источником проблемы:

[INFO] warning: Ignoring InnerClasses attribute for an anonymous inner class
[INFO] (org.osgi.framework.AdminPermission$1) that doesn't come with an
[INFO] associated EnclosingMethod attribute. This class was probably produced by a
[INFO] compiler that did not target the modern .class file format. The recommended
[INFO] solution is to recompile the class from source, using an up-to-date compiler
[INFO] and without specifying any "-target" type options. The consequence of ignoring
[INFO] this warning is that reflective operations on this class will incorrectly
[INFO] indicate that it is *not* an inner class.

Буду признателен за любую помощь.Вот полный вывод с включенной отладкой с консоли, чтобы вы могли более подробно рассмотреть ошибку: http://pastebin.com/5DPBihH0

Best.

Dama

Ответы [ 2 ]

3 голосов
/ 09 февраля 2012

Это была известная проблема, но я считаю, что она была исправлена ​​в android-maven-plugin версии 3.1.0.Последний - 3.1.1.Вы не опубликовали свой pom.xml, поэтому я не могу сказать, является ли это проблемой, но похоже, что это так.

Если по какой-то причине вы не можете выполнить обновление, примените следующую конфигурацию:

  <dex>
    <jvmArguments>
      <jvmArgument>-Xms256m</jvmArgument>
      <jvmArgument>-Xmx512m</jvmArgument>
    </jvmArguments>     
  </dex>

Вот проблема, сообщенная на их сайте: http://code.google.com/p/maven-android-plugin/issues/detail?id=146

А также в блоге Springsource: http://blog.springsource.org/2011/11/07/updated-maven-support-for-android-projects/

0 голосов
/ 09 февраля 2012

Я думаю, что это связано с этими предупреждениями:

[INFO] warning: Ignoring InnerClasses attribute for an anonymous inner class
[INFO] (org.osgi.framework.AdminPermission$1) that doesn't come with an
[INFO] associated EnclosingMethod attribute. This class was probably produced by a
[INFO] compiler that did not target the modern .class file format. The recommended
[INFO] solution is to recompile the class from source, using an up-to-date compiler
[INFO] and without specifying any "-target" type options. The consequence of ignoring
[INFO] this warning is that reflective operations on this class will incorrectly
[INFO] indicate that it is *not* an inner class.

Ответы, которые должны вам помочь:

Предупреждение "Игнорирование атрибута InnerClasses" убивает Eclipse
Что такое вывод предупреждения "Игнорирование атрибута InnerClasses" во время компиляции?
http://code.google.com/p/maven-android-plugin/issues/detail?id=26

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...