技术开发 频道

spring的aop学习

【IT168技术文档】面向方面编程 ( AOP) 提供从另一个角度来考虑程序结构以完善面向对象编程(OOP)。 面向对象将应用程序分解成 各个层次的对象,而AOP将程序分解成各个方面 或者说 关注点 。 这使得可以模块化诸如事务管理等这些横切多个对象的关注点。(这些关注点术语称作 横切关注点。)


Spring的一个关键组件就是AOP框架。 Spring IoC容器(BeanFactory 和ApplicationContext)并不依赖于AOP, 这意味着如果你不需要使用,AOP你可以不用,AOP完善了Spring IoC,使之成为一个有效的中间件解决方案,。


AOP在Spring中的使用:

· 提供声明式企业服务,特别是作为EJB声明式服务的替代品。这些服务中最重要的是 声明式事务管理,这个服务建立在Spring的事务管理抽象之上。

· 允许用户实现自定义的方面,用AOP完善他们的OOP的使用。


这样你可以把Spring AOP看作是对Spring的补充,它使得Spring不需要EJB就能提供声明式事务管理;或者 使用Spring AOP框架的全部功能来实现自定义的方面。

说了一堆,现在开始进入正题!

(本文不介绍spring的相关配置,请参考其他文档进行spring的配置)

首先看spring的配置文件

首先看spring的配置文件 

"http://www.springframework.org/dtd/spring-beans.dtd"> class="com.softbrain.wangzl.business.MethodTimeCostInterceptor"/> class="org.springframework.aop.framework.ProxyFactoryBean"> com.softbrain.wangzl.business.ITest MyInterceptor

 

下面一一对相应的bean进行说明1.

Test类实现了接口ITest,代码如下: public interface ITest { public abstract void select(String a) throws Exception; public abstract void update(); public abstract void delete(); } public class Test implements ITest { int a = 10; public void select(String s) throws Exception { for (int i=0;i<25000000;i++){ a = a*(a+a); } } public void update(){ for (int i=0;i<25000000;i++){ a = a*(a+a); } } public void delete(){ for (int i=0;i<25000000;i++){ a = a*(a+a); } }


为什么使用接口定义BO(business object)在下面介绍!


2.

class="org.springframework.aop.framework.ProxyFactoryBean"> com.softbrain.wangzl.business.ITest MyInterceptor com.softbrain.wangzl.business.ITest



这里用到了Interfaces,接口在java程序中的优点在这就不赘述,如果使用接口,spring容器会使用动态代理,如果不使用接口,可以在这里将上面那句话换成

true

这样容器会使用CGLIB代理,CGLIB和动态代理在性能上有微小的区别,对Spring 1.0来说,后者稍快。interceptorNames在spring的源码中是一个private String[] interceptorNames;这说明可以配置多个interceptor,这里只用了一个.ProxyFactoryBean的具体配置可以参考spring的源码

3.

class="com.softbrain.wangzl.business.MethodTimeCostInterceptor"/> class="com.softbrain.wangzl.business.MethodTimeCostInterceptor"/>



这是AOP的Interceptor类,代码如下

public class MethodTimeCostInterceptor { implements MethodInterceptor, Serializable{ static Logger log = null; /* (non-Javadoc) * @see org.aopalliance.intercept.MethodInterceptor#invoke(org.aopalliance.intercept.MethodInvocation) */ public Object invoke(MethodInvocation invocation) throws Throwable { log = Logger.getLogger(invocation.getMethod().getName()); long time = System.currentTimeMillis(); log.info("begin"); Object rval = invocation.proceed(); System.out.println(invocation.getMethod().getParameterTypes()); time = System.currentTimeMillis() - time; log.info("end"); System.out.println(time); return rval; } }


这里捕获所有的ITest接口的方法,计算运行时间并打印log 这里捕获所有的ITest接口的方法,计算运行时间并打印log接口的方法,计算运行时间并打印log这里问题来了,能否像spring的事务处理那样对指定的方法使用AOP哪?可以, select*

这里是用正则表达式来定义patterns,spring的正则表达式采用jarkata的oro,相应的对myAOPProxy进行修改 

class="org.springframework.aop.framework.ProxyFactoryBean"> com.softbrain.wangzl.business.ITest settersAndAbsquatulateAdvisor

 


这样一个简单的spring的AOP应用配置完了,当然这篇文章只是起一个抛砖引玉的作用,希望大家多来拍砖!

0
相关文章