为什么需要 Spring AOP?

微信公众号:大黄奔跑
关注我,可了解更多有趣的面试相关问题。

1. AOP 初窥

比如如下一段代码,仅仅根据商品 Id 获取商品信息

public GoodsVo getGoodsVoByGoodsId(long goodsId) {
    return goodsMapper.getGoodsVoByGoodsId(goodsId);
}

有时候为了便于观察执行情况,会在前后加上日志,这种都很常见吧。

public GoodsVo getGoodsVoByGoodsId(long goodsId) {
    Log.info("get Goods info, goodsId:" + goodsId);
    GoodsVo goodsVoByGoodsId = goodsMapper.getGoodsVoByGoodsId(goodsId);
    Log.info("get Goods info, goodInfos:" + goodsVoByGoodsId);
    return goodsVoByGoodsId;
}

好家伙,真正的业务代码,只有一行,额外的日志却有两行。这还是一个简单的需求,如果是生产中,每个反复都如此,业务代码会被淹没在 "额外的无用代码" 中,后续系统将变得及其难以维护。

1. 为什么需要 AOP

为了更好的解决这种问题,前辈们提出了 AOP (Aspect Oriented Programming),作为 OOP(Object Oriented Programming)的补充。

为什么叫做 Aspect 呢?其实就是一种对逻辑的抽象, Aspect 对于 AOP,相当于 Class 对于 OOP

Aspect 含义 <figcaption style="line&#45;height&#58; inherit&#59; margin&#58; 0px&#59; padding&#58; 0px&#59; margin&#45;top&#58; 10px&#59; text&#45;align&#58; center&#59; color&#58; rgb&#40;153&#44; 153&#44; 153&#41;&#59; font&#45;size&#58; 0&#46;7em&#59;">Aspect 含义 </figcaption>

AOP 是为了解决 OOP 不足的问题引入了,并不是一个单独的概念,都说面向切面,没有面?怎么切呢?

2. AOP 实现方式

AOP 是一种理念,而不是一种语言,上面说到 AOP 需要依托于某一种语言实现,就好比 OOP 的实现有 Java,C++ 等

最著名的莫过于 AspectJ ,其实就是一种 Java 版本的 ASpect。

动态代理

在运行期间,为对应接口动态生成对应的代理对象。

显著的缺点:所有需要织入的类都需要实现相应的接口

动态字节码增强

在动态构建字节码文件时,织入相应逻辑,真正做到不感知

缺点:如果需要扩展的类为 final 时,则无法进行扩展。

总结

本文简单介绍了,为什么需要 AOP , 其实 AOP 并不是 Java 中独有的,是一种思想。只有知道了为何而来,才能更加方便了解具体怎么做。

下一篇介绍 实现 AOP 的核心思想:动态代理模式。

#Java##学习路径#
全部评论

相关推荐

10-18 13:01
已编辑
西安理工大学 C++
小米内推大使:建议技能还是放上面吧,hr和技术面试官第一眼想看的应该是技能点和他们岗位是否匹配
点赞 评论 收藏
分享
1 3 评论
分享
牛客网
牛客企业服务