为啥spring中AOP 用的很少

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥spring中AOP 用的很少相关的知识,希望对你有一定的参考价值。

spring AOP不是用反射实现的,而bean的创建一般是这样做的。
spring里主要通过Java动态代理接口、cglib生成子类、AspectJ这三种方式来实现AOP。

通过AOP进行声明式事务管理应该是大家用的最多的吧。像权限校验和日志记录虽然也具备一定的横切性需求,但好像很少拿spring来做,权限控制框架倒是可以考虑与spring进行集成,细粒度的日志记录则根本无法真正利用AOP来做,原因在于业务方法记录日志的位置是不统一的,从而无法确定切入点。

但spring利用AOP还是干了不少事情的,随便翻看源码你都可以发现它们的影子。举个例子,spring里有一个javax.sql.DataSource的代理类TransactionAwareDataSourceProxy,它利用java的动态代理在运行时替换了原生DataSource的getConnection等诸多方法,最重要的是它使你的遗留系统具备了与spring集成并使用spring事务管理的能力,而这一切你只需要一个简单的配置,你并不知道spring在后台为你做了这些事情。

AOP是一种很有用的编程理念,语言和工具不应成为我们程序员思想的束缚,即使项目不用spring AOP你也可以在适当的契机把spring里好的想法拿来用,甚至你觉得不好还可以改造它,这样我们才能真正成为工具的主人而不是奴仆。
参考技术A AOP是通过反射的方式实现的,虽然方便,但是是以牺牲性能为代价的,一般如果收益不是很大的话,就不会用。

事务控制是一个非常好的收益,因此会使用AOP

Spring中的ioc和aop有啥作用?为啥要用ioc和aop?面试中多次被问到,求一个详细 清晰的解答...

还是需要去了解,多看看书!
IOC:控制反转,是一种设计模式。一层含义是控制权的转移:由传统的在程序中控制依赖转移到由容器来控制;第二层是依赖注入:将相互依赖的对象分离,在spring配置文件中描述他们的依赖关系。他们的依赖关系只在使用的时候才建立。简单来说就是不需要NEW一个对象了。

AOP:面向切面,是一种编程思想,OOP的延续。将系统中非核心的业务提取出来,进行单独处理。比如事务、日志和安全等。这个简单来说就是可以在一段程序之前或者之后做一些事。

Spring 的AOP和IOC都是为了解决系统代码耦合度过高的问题。使代码重用度高、易于维护。
不过AOP和IOC并不是spring中特有的,只是spring把他们应用的更灵活方便
参考技术A 我来说说我的理解:
面试的时候,尽量不要照本宣科,这样给面试官的印象是很差的。用自己的话理解是最好的。我先来将两个例子:
ioc,控制反转,这个指的就是我们获取对象的方式进行反转了,改变了。在使用spring之前是需要手动new出来的,是我们主动获取的。使用spring之后,是将这个获取的过程交给spring来管理,我们只需要告诉spring你需要什么就行了,它就会把东西给你。比如:在没有电商的时候,我们去上街买东西,需要考虑到这东西有没有,价钱多少,怎么搬回来,去有多远……等等无数个和主要的业务逻辑(买东西)无关的问题。这样就会扰乱主业务逻辑。当我们有了电商平台后,买东西时只需要两步。注册账号(装载bean),告诉电商你要的东西名字(通过名字获取Bean),然后就可以在门口收到东西了。这就是ioc。
aop,面向切面。在谈这个之前需要了解几个词:切面,切入点,织入,目标对象,通知。

我先解释下名字的意思,再讲故事。
切面:就是你要准备增强的那些方法。
切入点:就是具体织入的方法,定义了地点
织入:动词,就是将切面织入的过层
目标对象:被增强的类
通知:就是什么时候增强,定义了时间
好了,了解清楚上面的几个词的意思后,再听故事就容易多了。
aop的功能就是用来增强,在执行主业务的通知也顺带执行其他业务。如:老李上街办点事儿,走啊走,走到了老王家门前(切入点),老王看见老李问:去哪啊!

老李:上街办点事儿(目标类)
老王:那帮我顺便把这封信投到邮筒里吧。(切面),等到10点的时候邮局开门了去柜台投。(通知)
老李:好嘞。然后老李接过信。(织入)
老李继续走啊走,继续上街办事(增强后的目标类)。办完事后老李回家了。
以上就是aop。aop一般用来处理权限控制,日志记录,加载事务等非主要业务逻辑的事情。底层是采用cglib和jdk的动态代理实现的。
以上例子可能会有点不恰当,如有大神,望指点修正,谢谢!
参考技术B ioc为Inversion of Control意思是控制反转,AOP是面向切面。spring就是他们结合的容器框架。
在spring的bean结构中如<bean id="PersonDaoBean" class="..PersonDao"/>,在一个Service类中可以这样写 private PersonDao personDao = new PersonDaoBean();你看这样PersonDao对象就不用自己创建和维护了,交给了bean。也就是控制反转。
AOP设置拦截用户的业务方法,判断权限,有权限则可以执行调用的业务方法,没有权限则不可以。在拦截的时候出现环绕通知 ,前置通知,后置通知,例外通知,最终通知。
这是我的答案,望采纳,要是喜欢,请支持,很难打字的。

以上是关于为啥spring中AOP 用的很少的主要内容,如果未能解决你的问题,请参考以下文章

Spring中的ioc和aop有啥作用?为啥要用ioc和aop?面试中多次被问到,求一个详细 清晰的解答...

Spring AOP的用法

java框架--Spring XML AOP 配置基础

Spring AOP

Spring AOP

Spring AOP详解