Spring三级缓存问题?

使用三级缓存而不是二级缓存的原因是什么?
有的博客说是避免出现多个代理对象
还有的说是为了减少Bean对象引用的提前暴露
大家认为是为啥? #Java#
全部评论
二级缓存装的是半成品bean,考虑不用第三级只用前两级的情形:a实例化,放入二级缓存,属性填充 此时发现a依赖新bean b,去做bean b的创建,b实例化,放入二级缓存,属性填充 此时发现b依赖a 去二级缓存找a 命中了 给b装配上a。 在不考虑代理的情形,这是没问题。但如果a用了aop 真正该用的是a的aop增强的代理对象,但前面的逻辑b装配上的却是原始a! 第三级缓存我理解是去存了beanName,原始bean实例以及真正所需bean对象的创建逻辑。aop的话应该是用了个beanpostprocessor
2 回复
分享
发布于 2023-12-31 01:30 上海
三级缓存主要为了代理模式,做一个工厂,然后确定是否需要经过代理,然后将半成品(非代理/代理增强)放入二级缓存
2 回复
分享
发布于 2023-12-31 14:05 浙江
联易融
校招火热招聘中
官网直投
解决循环依赖吧
2 回复
分享
发布于 2023-12-31 16:03 陕西
应该是和bean的生命周期相关,好像最开始就是两级缓存,后面加入了动态代理,改成了三级缓存,我在别的地方看到过帖子
2 回复
分享
发布于 01-07 00:48 陕西
我觉得是保证bean的"单例属性",一个beanname对应一个bean,如果A有两个循环依赖,然后正好还进行了aop,不用三级缓存就会存两个代理对象。
1 回复
分享
发布于 01-10 19:47 广西
网上大部分说的什么第三级关于aop都是不对的,其本质原因是如果只有两级,那么每次调用lambda表达式都是创建一个新的对象,因为在一个完整的依赖流程没有结束前,每次调用都是返回一个新的bean。首先明确一点一个完整的bean是需要实例化+初始化都完成了才会被放入一级缓存,那么比如a依赖b和c,b依赖a,c依赖a,那么执行流程是实例化a,发现需要b,实例化b,发现需要a,去一级缓存找到a没找到,去二级缓存找a没找到,去三级缓存创建a,半成品a被保存到二级缓存(由于a还有c需要创建,所以a暂时只会留在二级缓存,不会去一级缓存),b里面a使用的就是半成品对象,b被放入一级缓存,(现在b的流程结束了,返回对象a),发现a还是需要c,实例化c,发现c也需要a,去一级缓存里找没找到a,去二级缓存里面找,找到半成品a了,直接拿来用。看到了关键了吗?如果没有二级缓存,那在这里,c同样会去调用lambda表达式弄一个新的a出来,这也破坏了单例了,彻底错了
1 回复
分享
发布于 01-21 18:56 上海
没有第二级缓存,无法判断是否存在循环依赖。
点赞 回复
分享
发布于 2023-12-31 01:25 浙江
使用三级不是二级的主要目的是为了解决循环依赖问题中,在装配时产生动态代理对象和初始对象
点赞 回复
分享
发布于 01-10 19:30 海南
m
点赞 回复
分享
发布于 01-25 00:55 广东
我觉得是本来aop代理是要在初始化之后生成的,但是如果没有三级缓存那你就必须在初始化之前给所有bean生成代理对象,这违背了spring结合aop的一个设计
点赞 回复
分享
发布于 01-26 14:17 陕西
m
点赞 回复
分享
发布于 02-04 20:58 广东
打破循环依赖
点赞 回复
分享
发布于 02-14 18:06 湖南
应该是为了在没有出现循环依赖的情况下延迟代理对象的生成。
点赞 回复
分享
发布于 04-11 14:39 湖北

相关推荐

5 16 评论
分享
牛客网
牛客企业服务