当前位置: 首页 > news >正文

AOP基础

黑马程序员JavaWeb开发教程

文章目录

  • 一、AOP概述
  • 二、AOP快速入门
    • 2.1 步骤
    • 2.2 AOP的使用场景
    • 2.3 AOP的优势
  • 三、AOP核心概念
    • 3.1 AOP核心概念
    • 3.2 AOP执行流程

一、AOP概述

  • AOP:Aspect Oriented Propragramming(面向切面变成、面向方面编程)其实就是面向特定方法编程
  • 场景:
    • 案例部分功能运行比较慢,定位执行耗时比较长的业务方法,此时需要统计每一个业务方法的执行耗时。
      • 记录案例开始前的时间
      • 运行案例
      • 记录案例执行完成后的时间,计算案例执行时间
  • 实现
    • 动态代理是面向切面变成最主流的视线。而SpringAOP是Spring框架的高级技术,旨在管理bean对象的过程中,主要通过底层的动态代理机制,对特定的方法进行编程。

二、AOP快速入门

2.1 步骤

  1. 导入依赖:在pom.xml中导入AOP的依赖
<!--        AOP依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency>
  1. 编写AOP程序:针对与特定方法根据业务需要进行编程
package com.itheima.mytlias.aop;import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;@Slf4j
@Component
@Aspect
public class TimeAspect {//指定当前方法可以作用在哪些方法上(com.itheima.mytlias.service)所有包的所有接口和方法上@Around("execution(* com.itheima.mytlias.service.*.*(..))")public Object recordTime(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {//1.记录方法开始时间long begin = System.currentTimeMillis();//2. 调用原始方法Object object = proceedingJoinPoint.proceed();//调用原始方法//3. 记录方法结束时间long end = System.currentTimeMillis();//4. 输出方法运行耗时log.info(proceedingJoinPoint.getSignature() + "执行耗时:{}ms", end - begin);return object;}
}
  1. 测试
  • 首先需要运行程序,之后打开前端页面执行一个功能就可以看到日志中打印出来的耗时提醒
    在这里插入图片描述

2.2 AOP的使用场景

  1. 记录曹组日志
  2. 权限控制
  3. 事务管理

2.3 AOP的优势

  1. 无代码侵入
  2. 减少重复代码
  3. 提高开发效率
  4. 维护方便

三、AOP核心概念

3.1 AOP核心概念

  1. 连接点:JoinPoint,可以被AOP控制的方法(暗含方法执行时的相关信息)
  2. 通知:Advice,指哪些重复的逻辑,也就是共性功能(最终体现为一个方法);也就是入门程序中的recordTime 方法
  3. 切入点:PointCut,匹配连接点的条件,通知会在切入点方法执行时被应用(实际被AOP控制的方法)
  4. 切面:Aspect,描述通知与切入点大的对应关系(通知切入点)
  5. 目标对象:Target,通知所应用的对象
    在这里插入图片描述
    在这里插入图片描述

3.2 AOP执行流程

http://www.lryc.cn/news/360136.html

相关文章:

  • EXSI虚拟机新增磁盘并将空间扩充到已有分区
  • 民国漫画杂志《时代漫画》第39期.PDF
  • 每天一个数据分析题(三百四十二)
  • c++会员消费积分系统
  • 如何获知表中数据被删除
  • 机器学习之sklearn基础教程
  • ES升级--04--SpringBoot整合Elasticsearch
  • eclipse如何debug
  • 无人售货机零售业务成功指南:从市场分析到创新策略
  • 开源代码分享(32)-基于改进多目标灰狼算法的冷热电联供型微电网运行优化
  • 7、架构-架构的安全性
  • LeetCode题练习与总结:路径总和Ⅱ--113
  • Java复数计算
  • MySQL-事务日志
  • PySide6 GUI 学习笔记——常用类及控件使用方法(常用类坐标点QPoint)
  • 算法练习——字符串
  • Flutter 中的 SliverOverlapInjector 小部件:全面指南
  • 7个Python爬虫入门小案例
  • linux 利用 ~$() 构造数字
  • 七大获取免费https的方式
  • JVM(Java虚拟机)笔记
  • 秒杀基本功能开发(显示商品列表和商品详情)
  • centos 记录用户登陆ip和执行命令
  • JZ2440笔记:DM9000C网卡驱动
  • 【数据结构】二叉树:简约和复杂的交织之美
  • 信号稳定,性能卓越!德思特礁鲨系列MiMo天线正式发布!
  • 编程学习技巧——实战
  • GPU学习(1)
  • TQSDRPI开发板教程:UDP收发测试
  • opencv进阶 ——(九)图像处理之人脸修复祛马赛克算法CodeFormer