如何选择Spring AOP的动态代理?JDK与CGLIB的适用场景

Spring AOP在默认情况下使用的动态代理方式,可以比作是餐厅里的"智能服务员助手"。

Spring AOP默认提供了两种动态代理方式:JDK动态代理CGLIB代理 。其选择取决于被代理的对象是否实现了接口,以及配置的代理模式 。默认情况下,Spring会优先使用JDK动态代理。如果目标类没有实现任何接口,Spring才会使用CGLIB代理。

智能服务员助手(JDK动态代理):

• 这位助手专门服务于那些已经明确告诉它自己有哪些"技能"(即实现了哪些接口)的服务员。

• 当顾客需要这些特定的服务时,智能服务员助手会拦截请求,并调用真正的服务员来完成工作,同时还可以在服务前后添加一些额外的服务,比如推荐菜品或收集顾客反馈。

• 但这位助手有个限制,它只能服务于那些明确声明了自己技能的服务员(即目标对象必须实现至少一个接口)。

而另一种动态代理方式 ,我们可以称之为"全能服务员培训师"(CGLIB动态代理)

• 这位培训师更加灵活,它不需要服务员提前声明自己的技能

• 它通过观察和模仿 服务员的工作方式(即继承目标类),来提供相同的服务

• 因此,即使服务员没有声明任何技能 (即目标类没有实现接口),全能服务员培训师也能提供服务。

• 但全能服务员培训师也有个限制 ,它无法模仿那些无法被继承的服务员(即final类或final方法)。

简单来说,Spring AOP默认使用的JDK动态代理适用于那些实现了接口的目标对象 ,而CGLIB动态代理则适用于那些没有实现接口的目标对象。两者在应用场景和限制上有所不同,开发者可以根据实际需求选择合适的代理方式。

相关推荐
颜酱7 分钟前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
掘金者阿豪10 分钟前
UUID的隐形成本:一个让数据库“慢下来”的陷阱
后端
用户0844652563723 分钟前
Docker 部署 MongoDB Atlas 到服务端
后端
岁岁种桃花儿36 分钟前
SpringCloud从入门到上天:Nacos做微服务注册中心(二)
java·spring cloud·微服务
Anita_Sun1 小时前
一看就懂的 Haskell 教程 - 类型推断机制
后端·haskell
Anita_Sun1 小时前
一看就懂的 Haskell 教程 - 类型签名
后端·haskell
七八星天1 小时前
C#代码设计与设计模式
后端
砍材农夫2 小时前
threadlocal
后端
神奇小汤圆2 小时前
告别手写HTTP请求!Spring Feign 调用原理深度拆解:从源码到实战,一篇搞懂
后端
布列瑟农的星空2 小时前
前端都能看懂的Rust入门教程(三)——控制流语句
前端·后端·rust