首先,Android依赖包冲突其实并不是简单的不同模块依赖了相同库的不同版本,因为系统会自动选择高版本,同时给这两个模块使用。冲突只存在两种情况
- 引用了本地jar文件
由于引用的jar是会直接编译到项目里的,如果项目的两个module同时引入了相同的本地jar文件, 就会存在相同的类有多个实现,及duplicated defined class。这种情况比较好分析和定位,去掉其中一个即可。 - 不同模块引用了相同的远程库(比如maven库)的不同版本,且这两个版本不兼容
这类冲突主要是Android Support类, 目前Android已经退出AndroidX包了。
这种情况就比较难分析,本文将就我曾经遇到过的一个案例来分析此类包冲突的解决方案流程。
问题分析
当时编译一个项目时遇到这个错误
Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes.
Program type already present: android.support.design.widget.CoordinatorLayout$Behavior
CoordinatorLayout$Behavior类存在多次定义。这个主要是因为这个类在support的低版本26.xx上,是在design库里的。而到了support的27.xx,这个类却到了support-core-ui库。