这篇文章主要介绍了springboot相互依赖server相互引用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
springboot相互依赖 server相互引用
public class RoleService{
@Autowired @Lazy
private UserServer userServer;
}
public class UserService{
@Autowired @Lazy
private RoleService roleService;
}
spring解决相互依赖的问题
构造器循环依赖
@Service
public class A {
public A(B b) { }
}
@Service
public class B {
public C (C c) { }
}
@Service
public class C {
public A (A a) { }
}
通过构造器注入构成的循环依赖,此依赖是无法解决的,只能抛出BeanCurrentlyInCreationException异常表示循环依赖
描述:创建A类是,构造器需要B类,那将去创建B,在创建B时又发现需要A类,则又去创建C类,最终在创建C时发现又需要A,从而形成一个环,没办法创建。
原理:Spring容器将每一个正在创建的bean标识符放在一个“当前创建bean池”中,bean标识符创建过程中将一直保持在这个池中,因为如果在创建bean过程中发现自己已经在“当前创建bean池”中时,将会抛出BeanCurrentlyInCreationException异常表示循环依赖;而对于创建完毕的bean将从“当前创建bean池”中清除掉。
setter循环依赖
@Service
public class A1 {
@Autowired
private B1 b1; }
@Service
public class B1 {
@Autowired
public C1 c1;
}
@Service
public class C1 {
@Autowired
public A1 a1;
}
通过setter注入方式构成的循环依赖。
原理:对于setter注入造成的依赖是通过Spring容器提前暴露刚完成构造器注入但未完成其他步骤(比如setter注入)的bean来完成的,而且只能解决单例作用域的bean循环依赖。
field属性注入循环依赖(prototype)
@Service @Scope("prototype") public class A1 {
@Autowired
private B1 b1; }
@Service @Scope("prototype")
public class B1 {
@Autowired
public C1 c1; }
@Service @Scope("prototype") public class C1 {
@Autowired
public A1 a1; }
报错
小结一下
Spring只能解决Setter方法注入的单例bean之间的循环依赖
ClassA依赖ClassB,ClassB又依赖ClassA,形成依赖闭环。Spring在获取ClassA的实例时,不等ClassA完成创建就将其曝光加入正在创建的bean缓存中。在解析ClassA的属性时,又发现依赖于ClassB,再次去获取
ClassB,当解析ClassB的属性时,又发现需要ClassA的属性,但此时的ClassA已经被提前曝光加入了正在创建的bean的缓存中,则无需创建新的的ClassA的实例,直接从缓存中获取即可。从而解决循环依赖问题。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程学习网。
本文标题为:springboot相互依赖 server相互引用方式
- ExecutorService Callable Future多线程返回结果原理解析 2023-06-01
- Java实现顺序表的操作详解 2023-05-19
- Spring Security权限想要细化到按钮实现示例 2023-03-07
- Springboot整合minio实现文件服务的教程详解 2022-12-03
- Java中的日期时间处理及格式化处理 2023-04-18
- JSP页面间传值问题实例简析 2023-08-03
- SpringBoot使用thymeleaf实现一个前端表格方法详解 2023-06-06
- 基于Java Agent的premain方式实现方法耗时监控问题 2023-06-17
- JSP 制作验证码的实例详解 2023-07-30
- 深入了解Spring的事务传播机制 2023-06-02