Java / Android / Eclipse:IllegalArgumentException:已经添加

时间:2012-11-13 09:32:02

标签: java android eclipse illegalargumentexception

我的Eclipse环境中有一个Java项目“ EDNA ”,它使用名为 libosm osmnavigation 的库。

enter image description here

我将包含 libosm osmnavigation 的“ EDNA ”导出到jar中。 EDNA.jar会在我的Android 2.2项目“ Tableted ”中导入(复制到libs文件夹)。 libosm osmnavigation 会自动添加:

enter image description here

Tableted 在“Java Build Path - > Projects”中没有设置任何内容。 “Java Build Path - > Libraries”看起来像这样:

enter image description here

当我点击Debug时,会发生以下错误:

[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

我还尝试引用该项目,而不是添加jar。但这会导致同样的错误。

1 个答案:

答案 0 :(得分:0)

它们是否已添加并标记在“订单和出口”标签下?
否则试试这个,这是一个普遍的问题,在我的意见红色中,它不能正确导出它们。