Spring三级缓存问题?

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

相关推荐

250311 一面 45min到岗时间和时长项目拷打。spring boot 的一些扩展点,你了解过吗?你是从什么时间开始就是做Java 的?spring bean的一些这个生命周期大概有哪些?JVM里面的一些参数,比如xms,xmx,这些你了解吗?比如说spring boot 项目启动的进程,它是 Java 进程,那个进程的参数大概长啥样你还记得吗?事务的 ACID 指的是什么?Kafka 你了解过里面的那个 topic 和 partition 有什么区别吗?主题里面假如有1万条消息,这个 topic 的 badcase 有 10 个,那我这个1万条消息是怎么分布的?Kafka为什么要有这个 partition 这个概念?消费者是按照 topic 去消费的还是按 position 去消费的?consumer group有了解吗?一个 consumer group 下面有 5 个节点,就比方说刚才那个 topic 下面有十个partition,有五个这个消费节点,它这个五个消费节点是怎么去消费这些 partition?Kafka 它的性能比用 其它mq 那些都要快,那你了解过Kafka 为什么能实现高吞吐量吗?zookeeper 你了解过吗?节点数奇数比较好还是偶数?mybatis里面那个#和$有什么区别?哪个是可以预编译,防止 SQL 注入的安全的是哪一种写法?mybatis的一级缓存和二级缓存有了解吗?链表还有堆,还有树,你哪个比较熟悉一点?手撕:删除链表的倒数第 N 个结点反问业务#腾讯##后端##暑期##实习##腾讯云#
查看21道真题和解析
点赞 评论 收藏
分享
评论
5
18
分享

创作者周榜

更多
牛客网
牛客企业服务