【SpringBoot】SpringBoot解决循环依赖🔄
在SpringBoot开发中,循环依赖是一个常见但又令人头疼的问题😫。当两个或多个Bean相互依赖时,就会形成循环依赖。比如A依赖B,B又依赖A,Spring容器在初始化时就会陷入死循环🌀。
循环依赖示例代码
```java
@Service
publicclassServiceA{
@Autowired
privateServiceBserviceB;//ServiceA依赖ServiceB
}
@Service
publicclassServiceB{
@Autowired
privateServiceAserviceA;//ServiceB又依赖ServiceA
}
```
Spring的解决方案💡
Spring通过三级缓存机制巧妙地解决了这个问题:
1.一级缓存:存放完全初始化好的Bean
2.二级缓存:存放早期暴露的Bean(未完成属性注入)
3.三级缓存:存放Bean工厂,用于生成早期Bean
```java
//Spring内部解决循环依赖的核心逻辑
ObjectearlyBean=getEarlyBeanReference(beanName,mbd,bean);
this.earlySingletonObjects.put(beanName,earlyBean);//放入二级缓存
```
最佳实践✅
1.重构设计:尽量避免循环依赖,考虑使用接口或中间层
2.使用@Lazy:延迟加载打破循环
```java
@Service
publicclassServiceA{
@Lazy
@Autowired
privateServiceBserviceB;
}
```
3.Setter注入:代替字段注入
```java
@Service
publicclassServiceA{
privateServiceBserviceB;
@Autowired
publicvoidsetServiceB(ServiceBserviceB){
this.serviceB=serviceB;
}
}
```
4.使用ApplicationContext:手动获取Bean
记住,虽然Spring提供了解决方案,但良好的设计才是根本!🌟循环依赖过多往往意味着架构需要优化,建议定期检查并重构代码结构🔍。
在SpringBoot开发中,循环依赖是一个常见但又令人头疼的问题😫。当两个或多个Bean相互依赖时,就会形成循环依赖。比如A依赖B,B又依赖A,Spring容器在初始化时就会陷入死循环🌀。
循环依赖示例代码
```java
@Service
publicclassServiceA{
@Autowired
privateServiceBserviceB;//ServiceA依赖ServiceB
}
@Service
publicclassServiceB{
@Autowired
privateServiceAserviceA;//ServiceB又依赖ServiceA
}
```
Spring的解决方案💡
Spring通过三级缓存机制巧妙地解决了这个问题:
1.一级缓存:存放完全初始化好的Bean
2.二级缓存:存放早期暴露的Bean(未完成属性注入)
3.三级缓存:存放Bean工厂,用于生成早期Bean
```java
//Spring内部解决循环依赖的核心逻辑
ObjectearlyBean=getEarlyBeanReference(beanName,mbd,bean);
this.earlySingletonObjects.put(beanName,earlyBean);//放入二级缓存
```
最佳实践✅
1.重构设计:尽量避免循环依赖,考虑使用接口或中间层
2.使用@Lazy:延迟加载打破循环
```java
@Service
publicclassServiceA{
@Lazy
@Autowired
privateServiceBserviceB;
}
```
3.Setter注入:代替字段注入
```java
@Service
publicclassServiceA{
privateServiceBserviceB;
@Autowired
publicvoidsetServiceB(ServiceBserviceB){
this.serviceB=serviceB;
}
}
```
4.使用ApplicationContext:手动获取Bean
记住,虽然Spring提供了解决方案,但良好的设计才是根本!🌟循环依赖过多往往意味着架构需要优化,建议定期检查并重构代码结构🔍。
2242

被折叠的 条评论
为什么被折叠?



