摘要:我们写aop的时候都会有个正则表达式,这个会去匹配方法,匹配到了以后,系统会将我们写的一些方法(通知)以及匹配的方法按照一定的顺序去执行
我们先从最原始的面向过程开始吧.首先看下
public class Test {
public static void main(String[] args) {
System.out.println("方法开始");//每次方法开始之前必须输出这句话 --①
System.out.println("==================="); --②
System.out.println("执行方法");
System.out.println("==================="); --③
System.out.println("方法结束");//每次方法结束之后必须输出这句话 --④
}
}
这个代码相信大家都能看懂输出的是什么.按照代码里面的要求,要是每次都是自己去敲代码的话,那每次就需要敲1234 这四行代码,这个时候面向过程就显得格外的冗余.所以我们就引入了面向对象.我们将开始的代码跟结束的代码封装进一个方法里面,这里我写在了静态方法里面
public class Test {
public static void main(String[] args) {
beforMethod();
System.out.println("执行方法");
afterMethod();
}
/**
* 方法开始前执行这个方法
*/
public static void beforMethod() {
System.out.println("方法开始");
System.out.println("===================");
}
/**
* 方法结束后执行这个方法
*/
public static void afterMethod() {
System.out.println("===================");
System.out.println("方法结束");
}
}
同样的输出结果,但是方法开始跟方法结束这两个的代码放进了方法体里面,就得到了复用的效果.这就是(OOP)
这个时候大家再想想,如果有100个方法执行前都要先执行Test.beforMethod(),执行结束后都要执行Test.afterMethod(),这不是又很麻烦吗.这个时候就是aop发挥的时候了.
首先我们在写aop的时候,都会先写一个匹配方法的表达式(专业术语叫做定义切点),我们可以把他认为,如果匹配了这个表达式,那我们就会把beforMethod()跟afterMethod()这两个方法加进去.这样执行出来的结果当然也是正确的.
了解了aop后还是知道一些aop的术语哦.