程序员晋级之路——初识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切面的例子!

相关文章
|
Linux 容器 Docker
Debian配置系统中文语言及环境
Debian配置系统中文语言及环境
12645 1
|
存储 数据库 C++
"深入剖析Python元组(tuple):与列表的对比、特性解析及高效应用场景展示"
【8月更文挑战第9天】Python元组与列表虽均用于存储元素集合,但有本质差异。元组不可变,创建后无法修改,适合保护数据不被意外更改的场景,如作字典键或传递固定值。列表则可变,支持动态增删改,适用于需频繁调整的数据集。元组因不可变性而在性能上有优势,可用于快速查找。两者各有千秋,根据具体需求选择使用。例如,元组可用于表示坐标点或日期,而列表更适合管理用户列表或库存。
732 1
|
机器学习/深度学习 存储 人工智能
存内计算芯片研究进展及应用—以基于NorFlash的卷积神经网络量化及部署研究突出存内计算特性
存内计算芯片研究进展及应用—以基于NorFlash的卷积神经网络量化及部署研究突出存内计算特性
|
语音技术 开发者 Python
python之pyAudioAnalysis:音频特征提取分析文档示例详解
python之pyAudioAnalysis:音频特征提取分析文档示例详解
1249 0
|
JSON Linux API
币安(binance)API接口
原文链接 币安API Rest-API 2018-01-04 基本信息 URL: https://api.binance.com JSON协议 数据默认按ASC(升序)排序,时间早的在上面 所有和时间有关的单位都是毫秒 HTTP 4XX : 请...
11555 1
|
存储 机器学习/深度学习 并行计算
vivo 推荐业务 x DeepRec:全链路优化实践
DeepRec提供大量的解决方案帮助vivo用户快速实施GPU推理,便于业务快速构建推荐服务及算法策略高效迭代。
MetaX窖管家产品介绍-数字孪生酒窖测温(硬件+软件)
针对酒窖窖池的实时测温硬件,以及配套软件。
177 0
|
Java API Apache
【小家Java】Java第二API之apache的commons-lang3工具包史上最完整的讲解(书写优雅代码必备工具)(上)
【小家Java】Java第二API之apache的commons-lang3工具包史上最完整的讲解(书写优雅代码必备工具)(上)
【小家Java】Java第二API之apache的commons-lang3工具包史上最完整的讲解(书写优雅代码必备工具)(上)