程序员晋级之路——初识AOP

简介: 程序员晋级之路——初识AOP

前言


何为AOP?AOP就是面向切面的编程。

何为面向切面的编程?就像高速公路的省界收费站一样,每条进出我们省的高速都会在省界上设立一个收费站,那么省界就是一个切面,收费站就是我们的处理方案,我们需要做的是定义省界这个面和在面上的收费站的功能。


应用场景


在项目完成之后,交付之前我们一般会对程序进行压力测试,在测试中怎么更加精准的定位系统运行的瓶颈呢?这时候你需要AOP监测每个接口甚至每个方法执行的时间!

在项目做异常处理时,我们怎样才能更加简单明了,将所有异常统一截取到同一个方法中进行处理?这时候你需要AOP将抛出的异常接受并处理!

AOP的定义非常灵活,可以是返回值类型,也可以是注释,也可以是某一个包下的所有方法或者指定方法,所以学习AOP之后,你不需要担心没有用武之地!


AOP结构


首先需要在这个类上添加一个@Aspect注释,这就声明了这个类是一个切面。

如下例子,将所有返回值为指定类型的方法定义为一个切面:

@Aspect
@Component
@Slf4j
public class ResultAspect {
  // 切入点  所有返回值类型是com.test.xbo包下ResultBO的方法
  @Pointcut("execution(public com.test.xbo.ResultBO *(..))")
  public void ResultAspect() {
  }
  // 环绕通知,参数必须为ProceedingJoinPoint,proceed就是被切面的方法
  @Around("ResultAspect()")
  public Object deAround(ProceedingJoinPoint joinPoint) throws Throwable {
      long startTime = System.currentTimeMillis();
      joinPoint.proceed();
      String str = "## 控制器运行时间:" + joinPoint.getSignature() + ":" + (System.currentTimeMillis() - startTime);
    return null;
  }
}


再如,我定义一个注释,将所有添加该注释的方法定义为一个切面:

1、定义一个注释,添加该注释的方法会打印出该方法执行的时间:


@Target({ ElementType.METHOD, ElementType.TYPE })
@Retention(RetentionPolicy.RUNTIME)
public @interface DoneTime {
  String param() default "";
}


2、定义一个切面

@Aspect
@Component
@Slf4j
public class DoneTimeAspect {
  @Around("@annotation(doneTime)")
  public Object around(ProceedingJoinPoint joinPoint, DoneTime doneTime) throws Throwable {
    long startTime = System.currentTimeMillis();
    Object o = joinPoint.proceed();
    String str = "## DoneTime-" + joinPoint.getSignature() + ":" + (System.currentTimeMillis() - startTime);
    log.error(str);
    return o;
  }
}

这样我们就完成了两个非常典型的AOP切面的例子!

相关文章
|
6月前
|
NoSQL Java 关系型数据库
大厂贬值裁员,我却凭借Java开发进阶面试秘籍(核心版)逆流而上
最近参加了面试或者身边有朋友在面试的兄弟有没有发现,现在的面试不仅会问八股文,还会考察框架、项目实战、算法数据结构等等,需要准备的越来越多。
75 0
|
3月前
|
缓存 运维 容灾
入行5年,谈谈我在阿里做测试开发的经验
作者在阿里一直从事测试开发相关工作,这几年学习很多、收获很多,作者希望给还在该方向摸爬滚打的同学一些启发和方向。
|
5月前
|
Java
启航Java编程:基础三部曲-第三部
启航Java编程:基础三部曲-第三部 控制流的艺术:条件判断与循环结构深入浅出
33 1
|
5月前
|
前端开发 开发者
编织代码的诗篇:我的技术感悟之旅
【6月更文挑战第10天】在数字世界的织布机上,每一行代码都如同细腻的丝线,交织成我技术生涯的华美篇章。本文将带你穿梭于我与代码共舞的日子,感受那些静默中涌现的灵感,以及在挑战与创造间不断进化的思维。
34 3
|
4月前
|
Java 数据库连接 开发者
从零到一:JAVA反射技术的“逆袭”之路
【7月更文挑战第1天】Java反射技术,从高级特性走向普及,核心是Class类,用于运行时检查和操作类信息。在Spring等框架中,反射实现DI和AOP,提升灵活性。动态代理通过Proxy和InvocationHandler实现方法拦截。反射现已成为Java不可或缺的工具,未来潜力无限。
20 0
|
5月前
|
Oracle IDE Java
启航Java编程:基础三部曲-第一部
启航Java编程:基础三部曲-第一部 揭秘Java:从Hello World开始的编程之旅
35 0
|
Java 测试技术 API
美团java研发岗二面:微服务问题被虐哭了,直到看到这些知识点
微服务架构基于一个概念,其中所有服务应该能够彼此交互以构建业务功能。因此,要实现这一点,每个微服务必须具有接口。这使得 Web API 成为微服务的一个非常重要的推动者。RESTful API 基于 Web 的开放网络原则,为构建微服务架构的各个组件之间的接口提供了最合理的模型。
91 0
美团java研发岗二面:微服务问题被虐哭了,直到看到这些知识点
|
前端开发 JavaScript Java
有哪些值得学习的spring boot开源项目;默默无闻但有趣的编程语言; 面试的时候怎么介绍项目经验比较出彩|极客观点
有哪些值得学习的spring boot开源项目;默默无闻但有趣的编程语言; 面试的时候怎么介绍项目经验比较出彩|极客观点
120 0
|
设计模式 运维 Kubernetes
15年老司机聊程序员成长的28个要点
15年老司机聊程序员成长的28个要点
371 1
|
架构师
10年技术管理实战不传心法
10年技术管理实战不传心法
140 0
10年技术管理实战不传心法