4

我只添加到一个现有的完全工作的项目中,文件com/android/vending/billing/IMarketBillingService.aidl

(我还没有添加任何其他内容(来自 market_billing 示例),因为我什至还没有尝试使用该服务)

它可以完美地编译和构建,但是当我尝试运行它时,我会在控制台中收到以下信息:

java.lang.IllegalArgumentException: already added: Lcom/android/vending/billing/IMarketBillingService$Stub$Proxy;
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 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
Dx  at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
Dx  at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
Dx  at java.lang.reflect.Method.invoke(Unknown Source)
Dx  at com.android.ide.eclipse.adt.internal.build.DexWrapper.run(DexWrapper.java:179)
Dx  at com.android.ide.eclipse.adt.internal.build.BuildHelper.executeDx(BuildHelper.java:745)
Dx  at com.android.ide.eclipse.adt.internal.build.builders.PostCompilerBuilder.build(PostCompilerBuilder.java:634)
Dx  at org.eclipse.core.internal.events.BuildManager$2.run(BuildManager.java:629)
Dx  at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
Dx  at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:172)
Dx  at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:282)
Dx  at org.eclipse.core.internal.events.BuildManager.build(BuildManager.java:363)
Dx  at org.eclipse.core.internal.resources.Project$1.run(Project.java:545)
Dx  at org.eclipse.core.internal.resources.Workspace.run(Workspace.java:1975)
Dx  at org.eclipse.core.internal.resources.Project.internalBuild(Project.java:524)
Dx  at org.eclipse.core.internal.resources.Project.build(Project.java:123)
Dx  at com.android.ide.eclipse.adt.internal.project.ProjectHelper.doFullIncrementalDebugBuild(ProjectHelper.java:961)
Dx  at com.android.ide.eclipse.adt.internal.launch.LaunchConfigDelegate.launch(LaunchConfigDelegate.java:146)
Dx  at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:853)
Dx  at org.eclipse.debug.internal.core.LaunchConfiguration.launch(LaunchConfiguration.java:702)
Dx  at org.eclipse.debug.internal.ui.DebugUIPlugin.buildAndLaunch(DebugUIPlugin.java:924)
Dx  at org.eclipse.debug.internal.ui.DebugUIPlugin$8.run(DebugUIPlugin.java:1128)
Dx  at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54)
Dx 3 errors; aborting
Conversion to Dalvik format failed with error 1

知道为什么会这样吗?

注意:这个添加的.aidl文件不是外部 jar,所以这里的答案对我来说没有帮助。

更新:我删除了那个可疑.aidl文件,清理了项目,但问题并没有消失。诡异的。

更新:我知道!在我将 SDK 从 9 版“升级”到 16 版之前,我刚刚尝试运行一个曾经完美运行的现有项目,并且在那里我也遇到了同样的错误。我知道我应该避免这种“升级”。现在,我不得不浪费时间解决一个在我按计划升级之前不应该出现的问题,而不是在我被迫升级时,因为无法进行有计划和受控的迁移。应用发布延迟...

更新:似乎与错误的自动转换有联系default.propertiesproject.properties但尽管我手动更正了所有转换错误,但问题仍然存在。我现在没有开发环境。这是荒唐的。

4

2 回答 2

6

问题终于解决了,使用来自惊人的 @TheTerribleSwiftTomato 的解决方案。

这都是由“ Android SDK 工具中库项目的更改,r14 ”引起的。

感谢@Google 让我的生活变得如此悲惨。如果您在系统行为中引入了根本性的变化,请不要在我还没有准备好吞噬它附带的所有信息时强迫我从 SDK 9“升级”到 SDK 16(或者至少发出一个错误)可以直接指向此更改的消息)。

另一方面,真的感谢@Google 介绍了期待已久、渴望已久的功能,该功能将每个库项目生成到自己的 JAR 文件中。这是一个真正的救生员,只能从 SDK Tools r14开始使用。哇!

于 2012-01-12T06:01:29.867 回答
1

如果您使用的是 cocos2dx。简单的问题是您的工作区没有使用 android sdk 配置。只需使用您的 IDE(eclipse 或 android studio)配置一个新的工作区或现有的工作区。它对我有用

于 2017-04-16T20:13:21.967 回答