IDEA 解决循环依赖(A–>B–>A)的问题

背景

今天,用maven 打包的时候,提示有循环依赖,记录一下踩过的坑。

问题

(1)IDEA中依赖报错Error:java: Annotation processing is not supported for module cycles…

一开始出现的是上面的错误提示,以下的解决方案,是在解决代码上的循环依赖后,再进行的操作,否则会报错。

解决步骤

(1)先 选择file->project structure->Modules

img

把依赖中的包删掉,最后点击ok ,然后再整体 rebuild 项目一下。

img

(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模块

image-20220509163429667

image-20220509163442374

要想把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项目相互依赖/循环依赖/双向依赖的问题

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐