自从更新到ADT 14,我不能再构建我的项目。它在更新之前构建得很好。

错误:

[2011-10-23 16:23:29 - Dex Loader] Unable to execute dex: Multiple dex files define Lcom/myapp/R$array;
[2011-10-23 16:23:29 - myProj] Conversion to Dalvik format failed: Unable to execute dex: Multiple dex files define Lcom/myapp/R$array;

类似的问题也有报道,我尝试了其中的建议,包括

重新启动Eclipse。 清理项目和重建-禁用“项目->自动生成”选项,然后“清理”和“生成”项目,然后尝试运行。将“自动构建”选项重置为开启 重新安装Android开发者工具 重新安装Eclipse(更新到最新版本3.7.1) 创建一个从文件系统导入的新项目 从subversion创建一个新项目。


当前回答

对我来说,这个问题只存在,只要有Android库项目涉及到我的项目。所以当我删除所有的库,并按照你说的那样,我可以再次运行我的应用程序。 如果涉及到库,即使是删除箱子的技巧也行不通。

我不明白为什么这个错误今天第一次出现,因为我现在使用ADT 14好几天了。不过还有其他虫子让我很开心。

其他回答

当我在项目中添加ActionBarSherlock作为库时,我也遇到了类似的问题。Eclipse ADT v21.0预创建的dex文件据说是为了更快地构建项目。这些dex文件与lib文件夹中的一些jar文件相同。所以只保留一个,删除另一个。我删除了lib文件夹中的那些,因为dexed文件是自动生成的。

我来晚了,但加上我自己的经验,这样我以后可以再找:)

我在升级android sdk和eclipse插件后遇到了这个问题。没有升级不受惩罚!

我的问题与库项目有关,我的应用程序引用标准java项目和android库项目。我注意到Java Build Path设置在Source列表中包含了android库项目src和res文件夹(为每个在Source中提到bin的人投票,src和res也是一个问题)。

所以解决方案是:

在source列表和project列表的Java Build Path部分中删除所有引用的Android库源代码和项目引用 确保项目列表中列出了纯java依赖项,并在Order和Export选项卡中勾选,以便类包含在apk中 确保所有Android库依赖都列在项目属性的Android部分,在选中SDK版本下面的库部分。

从其他解决方案中拼凑出所有这些解决方案需要很长时间!唷!

在项目资源管理器中选择项目,右键单击并选择属性-> Java构建路径-> Source ->选中源文件夹的“允许输出文件夹”复选框

正如其他人所提到的,当您的构建路径中有同一个类的多个副本时,就会发生这种情况——在类路径中包含bin/是保证这个问题的一种方法。

对我来说,这发生在我将android-support-v4.jar添加到我的libs/文件夹时,eclipse不知怎么地在bin/classes/android-support-v4.jar中添加了第二个副本。

删除bin/classes中的额外副本解决了问题-不确定Eclipse为什么要在那里复制。

你可以用

grep jar -r yourroffendingclassname YourApp | grep jar

这个问题发生在我身上,我在我的libs文件夹中有一个外部的。jar,名为gson-2.2.2.jar,但出于某种原因,其中有两个,gson-2.2.2.jar和gson-2.2.2.jar(1),我简单地删除了后者,我的项目再次建立良好。