> 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包有一定的了解,然后通过寻找离错误信息最近的那条异常警告进行分析,找到重复的依赖包删除。如果了解不够,建议备份项目之后逐个试验,直到找到目标为止。