IDEA 解决循环依赖(A–>B–>A)的问题
背景
今天,用maven 打包的时候,提示有循环依赖,记录一下踩过的坑。
问题
(1)IDEA中依赖报错Error:java: Annotation processing is not supported for module cycles…
一开始出现的是上面的错误提示,以下的解决方案,是在解决代码上的循环依赖后,再进行的操作,否则会报错。
解决步骤
(1)先 选择file->project structure->Modules
把依赖中的包删掉,最后点击ok ,然后再整体 rebuild 项目一下。
(2) 检查该模块下的 pom.xml 文件,手动把循环的依赖去掉。
我自己是这一步解决的,在第一步去掉循环的依赖后,clean,IDEA又会重新导入那个循环的依赖。只有在pom.xml 手动删除后,才其效果。
(2) Failed to execute goal org.apache.maven.plugins:maven-clean-plugin:3.1.0:clean (default-clean)
后来又出现了这个,这是因为你在项目启动的环境下,又在运行maven 的clean和install导致的,可以先停掉应用,再打包 。
通过Analyze 分析去查找循环依赖
IDEA菜单栏中打开Analyze->Analyze Module Dependencies…看到有的模块被红色的标出来了,并且右边显示了循环依赖。选中红色的存在循环依赖的模块右键选中Open Module Settings删除不该出现的依赖即可。
说实话,这一步我操作时,没有出现红色的,是因为代码上我就没有依赖的地方,才不会有红色的提示。
解决代码层面上的依赖的思路
(1) 合并A、B、C三个模块为D模块
要想把A、B、C三个模块整合在一起编译,需要借助build-helper-maven-plugin插件,这个插件在Maven构建周期提供一些辅助功能,具体的可以看这篇文章 解决Maven项目相互依赖/循环依赖/双向依赖的问题
(2) 是通过重构,从根本上消除循环依赖
目前也知道2个重构的思路 第一个办法是平移,比如A和B互相依赖,那么可以将B依赖A的那部分代码,移动到工程B中,这样一来,B就不需要继续依赖A,只要A依赖B就可以了,从而消除循环依赖 第二个办法是下移,比如A和B互相依赖,同时它们都依赖C,那么可以将B和A相互依赖的那部分代码,移动到工程C里,这样一来,A和B相互之间都不依赖,只继续依赖C,也可以消除循环依赖 这两种重构方式都是可行的,具体采用哪种方式要根据实际情况来判断。不管采取哪种方式,都需要对代码进行修改,有时候并不是那么容易的
参考文章
解决Maven项目相互依赖/循环依赖/双向依赖的问题
|