3

このエラーに関する多くのスレッドを見てきましたが、私の奇妙なシナリオをカバーするスレッドはありません。まず基本:

私は 6 つのプロジェクトを持っています。これらはすべて、アプリケーションの構造を模倣する縮小されたテスト プロジェクトであり、ビルドを機能させるためだけに使用しています。それらの依存関係は次のとおりです。

  • exampleLibは、他の jar を必要としないライブラリです
    • Widget.java を含む
  • exampleLib2は、他の jar を必要としないライブラリです。
    • Widget2.java を含む
  • exampleLibNesterは、 exampleLibexampleLib2を必要とするライブラリです。
    • WidgetPartDeux.java が含まれています
  • exampleLibNester2は、 exampleLibexampleLib2、およびexampleLibNesterを必要とするライブラリです
    • WidgetPartDeux2.java が含まれています
  • exampleUserは、 exampleLibexampleLib2exampleLibNester、およびexampleLibNester2を必要とするアプリケーションです
    • TheActivity.java が含まれています
  • exampleTestは、 exampleUser を計測するテスト アプリケーションで、 exampleLibexampleLib2、およびexampleLibNesterを必要とします
    • WidgetTest.java を含む

Windows でローカルに ant を使用してこれらのアプリケーションをビルドすると、正常install testに動作し、テストの実行に使用できます。Linux を実行している CI サーバーでビルドしようとすると、「既に追加されています」という恐ろしいエラー メッセージが表示されます。

-dex:
  [dex] Converting compiled files and external libraries into /apps/pos360/jenkins/.hudson/jobs/James-Test/exampleLibUser/bin/classes.dex...
   [dx]
   [dx] UNEXPECTED TOP-LEVEL EXCEPTION:
   [dx] java.lang.IllegalArgumentException: already added: Lcom/example/nester/WidgetPartDeux;
   [dx]     at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123)
   [dx]     at com.android.dx.dex.file.DexFile.add(DexFile.java:163)
   [dx]     at com.android.dx.command.dexer.Main.processClass(Main.java:486)
   [dx]     at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455)
   [dx]     at com.android.dx.command.dexer.Main.access$400(Main.java:67)
   [dx]     at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109)
   [dx]     at com.android.dx.command.dexer.Main.processOne(Main.java:418)
   [dx]     at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329)
   [dx]     at com.android.dx.command.dexer.Main.run(Main.java:206)
   [dx]     at com.android.dx.command.dexer.Main.main(Main.java:174)
   [dx]     at com.android.dx.command.Main.main(Main.java:91)
   [dx]
   [dx] UNEXPECTED TOP-LEVEL EXCEPTION:
   [dx] java.lang.IllegalArgumentException: already added: Lcom/example/lib/Widget;
   [dx]     at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123)
   [dx]     at com.android.dx.dex.file.DexFile.add(DexFile.java:163)
   [dx]     at com.android.dx.command.dexer.Main.processClass(Main.java:486)
   [dx]     at com.android.dx.command.dexer.Main.processFileBytes(Main.java:455)
   [dx]     at com.android.dx.command.dexer.Main.access$400(Main.java:67)
   [dx]     at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:394)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:245)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:131)
   [dx]     at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:109)
   [dx]     at com.android.dx.command.dexer.Main.processOne(Main.java:418)
   [dx]     at com.android.dx.command.dexer.Main.processAllFiles(Main.java:329)
   [dx]     at com.android.dx.command.dexer.Main.run(Main.java:206)
   [dx]     at com.android.dx.command.dexer.Main.main(Main.java:174)
   [dx]     at com.android.dx.command.Main.main(Main.java:91)
   [dx] 2 errors; aborting

classes.jar ファイルを調べて、exampleLibNester2 がそれらのクラスをその jar にプルしていることを確認できますが、それを防ぐ方法も、Linux ボックスでは実行するのに Windows では実行しない理由もわかりません。どちらの SDK も最新バージョンに更新されています。

4

2 に答える 2

0

ライブラリ プロジェクトで .jar ファイルをビルドするとき。ファイル AndroidManifest.xml にアクセス許可を追加しないでください (純粋な AndroidManifest で十分です)。必要なすべての権限をメイン プロジェクトのマニフェスト ファイルに追加するだけです。

または、単にライブラリ プロジェクトをメイン プロジェクトにインポートし、.jar を使用しないこともできます。

于 2014-08-20T01:32:19.423 に答える
0

私が理解しているように、Android ビルドのプロジェクト構造は R14 で変更されました。

この記事に従って、プロジェクトのビルド パスを確認し、_src で終わるフォルダーを削除することをお勧めします: @foxykeep : How to fix the "conversion to Dalvik format failed" . エラー名にもかかわらず、スタック トレースは同じエラーであり、同じ問題のように見えます。

于 2012-08-02T20:35:05.570 に答える