finished with non-zero exit value 2问题的常用解决方案

     由于开发小组中有人用的是Eclipse,有人用的是Android Studio,在使用svn版本控制的时候不是很方便,我用Android Studio下载别人的Eclipse项目的时候最容易出现的问题是:Error:Execution failed for task ':dexDebug'.

> com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExceException: Process 'command 'D:\Android\Java\jdk1.8.0_45\bin\java.exe'' finished with non-zero exit value 2,最后的value 2也可能是value 1,以前总是稀里糊涂的解决了,认为并不常见,所以没有过多在意,但是最近一周以来,该问题反复出现,于是下决心彻底解决这个问题。

这个错误从字面上看来是Gradle构建的项目在编译执行的过程中出现了问题,但具体是什么问题这里不能明显地看出来,这时候就要从错误的位置往上找,找到最近的一个警告,大体意思是一个不能解决的异常,然后可能是该异常导致了下面的错误,以致程序无法编译运行。我反复出现的警告是:com.android.dex.DexException: Multiple dex files define Lorg/apache/http/entity/mime/FormBodyPart;

分析上面的一段异常信息,apache.http.entity.mime.FormBodyPart,这是我引入的一个依赖包,当然,这只是其中一次的异常信息,但大体上,前面的信息都是Multiple dex files define,意为重复的dex文件定义。几经查找,发现这是由于项目里面引入的重复的依赖包导致的,我在引入了http.mime.4.1.1之后又引入了http.mime.4.0.1,包括之前的几次类似问题,大抵是因为猜想可能以后要用到某些jar包,所以提前引入了,结果到用的时候发现引入的并不能用,于是重新引入的其他功能相同的jar包,而之前引入但没有用得着的却忘了删除了。

问题的原因大概就是如此,解决方法是删除重复的这依赖包,首先,在Libs文件夹下找到多余的jar包删除,然后在build.gradle文件里面的dependencies{}里面删除依赖,如果使用的compile fileTree(dir: 'libs', include: '*.jar')方法添加所有libs文件夹下面的Jar包的话,只需要重新Sync一下就行了。

最后,关于如何寻找重复或者无用的jar包,需要对自己的项目和引入的jar包有一定的了解,然后通过寻找离错误信息最近的那条异常警告进行分析,找到重复的依赖包删除。如果了解不够,建议备份项目之后逐个试验,直到找到目标为止。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值