2012-11-13 42 views
1

我有一個Java項目 「EDNA」 在使用圖書館稱爲libosmosmnavigation我的Eclipse環境。的Java /安卓/ Eclipse的:拋出:IllegalArgumentException:已添加

enter image description here

我出口 「EDNA」 含libosmosmnavigation成jar。 EDNA.jar被導入到我的Android 2.2項目「Tableered」(複製到libs文件夾)中。 libosmosmnavigation都會自動添加:

enter image description here

片劑化無關,在 「Java構建路徑 - >項目」 進行設置。 「Java構建路徑 - >庫」是這樣的:

enter image description here

點擊調試時出現以下錯誤:

[2012-11-13 09:53:20 - Tableted] Dx bad class file magic (cafebabe) or version (0033.0000) 
...while parsing de/hk/econnect/math/CHull.class 
...while processing de/hk/econnect/math/CHull.class 
[2012-11-13 09:53:20 - Tableted] Dx 
UNEXPECTED TOP-LEVEL EXCEPTION: 
java.lang.IllegalArgumentException: already added:  Lcom/bretth/osmosis/core/xml/v0_5/XmlDownloader; 
at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:123) 
at com.android.dx.dex.file.DexFile.add(DexFile.java:163) 
at com.android.dx.command.dexer.Main.processClass(Main.java:486) 
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 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at com.android.ide.eclipse.adt.internal.build.DexWrapper.run(DexWrapper.java:180) 
at com.android.ide.eclipse.adt.internal.build.BuildHelper.executeDx(BuildHelper.java:703) 
at com.android.ide.eclipse.adt.internal.build.builders.PostCompilerBuilder.build(PostCompilerBuilder.java:577) 
at org.eclipse.core.internal.events.BuildManager$2.run(BuildManager.java:728) 
at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42) 
at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:199) 
at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:321) 
at org.eclipse.core.internal.events.BuildManager.build(BuildManager.java:396) 
at org.eclipse.core.internal.resources.Project$1.run(Project.java:618) 
at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:2344) 
at org.eclipse.core.internal.resources.Project.internalBuild(Project.java:597) 
at org.eclipse.core.internal.resources.Project.build(Project.java:124) 
at com.android.ide.eclipse.adt.internal.project.ProjectHelper.doFullIncrementalDebugBuild(ProjectHelper.java:1000) 
at com.android.ide.eclipse.adt.internal.launch.LaunchConfigDelegate.launch(LaunchConfigDelegate.java:147) 
at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:854) 
at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:703) 
at org.eclipse.debug.internal.ui.DebugUIPlugin.buildAndLaunch(DebugUIPlugin.java:937) 
at org.eclipse.debug.internal.ui.DebugUIPlugin$8.run(DebugUIPlugin.java:1141) 
at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54) 
[2012-11-13 09:53:20 - Tableted] Dx 10 warnings 
[2012-11-13 09:53:20 - Tableted] Dx 1 error; aborting 
[2012-11-13 09:53:20 - Tableted] Conversion to Dalvik format failed with error 1 

取而代之的將瓶子我也試圖引用該項目。但是這會導致相同的錯誤。

+0

你是什麼意思「自動添加libosm和osmnavigation」?我不認爲Android SDK/ADT具有這種將傳遞依賴關係自動公開到libs /文件夾的功能。它必須由某人添加。最簡單的解決方案是從libs中刪除libosm和osmnavigation,如果它們是運行時只依賴於你的應用程序項目,你應該沒問題。 – yorkw

回答

0

它們是否在「訂單&導出」選項卡下添加並標記?
否則嘗試這一點,這是一個普遍問題,在我的意見紅色,它不會讓他們正確導出。

+0

是的,它們在「Java構建路徑 - >順序和導出」下進行檢查,即列表中的最後一個條目。 – Norbert

+0

搬家,定位事宜。 –

+0

我將libosm和osmnavigation移到列表的頂部,它沒有什麼區別。 – Norbert

相關問題