我只添加到现有的完全工作项目中,该文件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
任何想法why这正在发生吗?
注意:这里添加了.aidl
文件是not一个外部罐子,所以答案here对我的情况没有帮助。
Update:我删除了那个可疑的.aidl
文件,清理项目,但问题并没有消失。诡异的。
Update:我就知道!我只是尝试运行一个现有的项目,在我将 SDK 从 9“升级”到 16 之前,该项目曾经运行得很好,但我也遇到了同样的错误。我知道我应该避免这种“升级”。现在我必须浪费时间来解决一个不应该出现的问题,直到我按照计划升级,而不是当我升级时forced到,而无法进行有计划和受控的迁移。应用程序发布延迟...
Update:似乎有一个联系buggy自动转换自default.properties
to project.properties
但尽管我手动纠正了所有转换错误,问题仍然存在。我现在没有开发环境了。这是荒唐的。
问题终于解决了,使用这个解决方案来自令人惊叹的@TheTerribleSwiftTomato。
这一切都是因为“Android SDK 工具中库项目的更改,r14".
谢谢@Google 让我的生活变得如此悲惨。如果您对系统行为进行了彻底的改变,当我还没有准备好吞噬它附带的所有信息时,不要强迫我从 SDK 9“升级”到 SDK 16(或者至少发出一个错误)消息可以直接指向此更改)。
另一方面,真正感谢@Google 介绍了期待已久、渴望已久的功能:将每个库项目生成到自己的 JAR 文件中。这是真正的救星,只能通过 SDK 工具获得r14在。哇!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)