build过程中没有出问题,run的时候出现如下错误:
Execution failed for task ':sample:transformClassesWithJarMergingForDebug'.
> com.android.build.api.transform.TransformException: java.util.zip.ZipException: duplicate entry: com/nostra13/universalimageloader/BuildConfig.class原因是在某个模块中导入了某个包,在另一个依赖该模块的模块中又一次导入了某个包(可能是不同的版本,所以一定要细心,只要出现同样的包名和类名就会出现重复入口问题),导致重复导包,出现问题。我这里是library模块中已经存在
universal-image-loader
库了,而在sample主模块gradle中又一次添加了
compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.5'
该库,所以导致了重复入口,去掉这一句导包语句就可以了。
解决方法:将重复的包保留子模块中的一份即可,其它的删除。
注意:重复导包也有可能是依赖了不同版本号的库,只能保留一份。
还有一点我测试的时候发现:
compile 'com.squareup.okhttp:okhttp:2.4.0' compile group: 'com.squareup.okhttp3', name: 'okhttp', version: '3.10.0'这两条语句导入了同一个包,只不过是不同版本的,在运行的时候却没有报错,原因是这个包的类进行了重构,可以说是不兼容了,同一个类被移动到了不同的包名中,所以没有产生冲突。
okhttp:2.4.0和okhttp:3.10.0的包名已经不一样了,截图如下: