第一章 AOP
关于AOP,通常我们会使用AspectJ注解来做,共有6中切面
- 前置:@Before
- 后置:@After
- 返回值:@AfterReturing
- 异常:@AfterThrowing
- 环绕:@Around:可以理解为以上四种的集合
- 引用(不常用)
比较难理解的两个部分:
- 连接点:JoinPoint、ProceedJoinPoint
- 连接点其实就是切面表达式覆盖的方法,根据该连接点可以获取多个信息,常用的如下:
- getSignature():获取当前方法的返回值、全类名、参数类型,例:Shop com.xxx.firstboot.dao.ShopDao.getShop(int)
- getTarget():获取当前方法所属的类实例,例:com.xxx.firstboot.dao.ShopDao@72f97c4f
- getArgs():获取当前方法的参数,例:[Ljava.lang.Object;@6fbd538a
- JoinPoint习惯性的用在除了@Around中,ProceedJoinPoint习惯性的用在@Around中(因为需要使用ProceedJoinPoint的proceed()方法进行目标方法的执行)
- 连接点其实就是切面表达式覆盖的方法,根据该连接点可以获取多个信息,常用的如下:
- 切点表达式:
- execution(* com.xxx.firstboot.dao.*.*(..))只需要记住这一个就可以
- 第一个*:代表任意权限和返回类型,例:public Shop,如果需要明确指定,就指定
- 第二个*:代表这个包下的所有类,例:ShopDao,如果需要明确指定,就指定
- 第三个*:代表类下的所有方法,例:getShop,如果需要明确指定,就指定
- ..:代表方法的入参类型可以是任意类型、任意数量(包括0个)的,例:int,如果需要明确指定,就指定
- 切点表达式就是方法(连接点)的匹配表达式
- execution(* com.xxx.firstboot.dao.*.*(..))只需要记住这一个就可以
两个补充点:
- 多个切面可以通过@Order(数字)这个注解来制定织入顺序,例:@Order(1),数字越小,越先织入,该注解用在切面上(即切面类上)
- 切点表达式可以重用,如下会演示
from: https://www.cnblogs.com/java-zhao/p/5415893.html
第一章 AOP的更多相关文章
- Spring3实战第一章 Aop 切面 XML配置
刚看spring3实战书籍第一章 切面以前没有关注过 现在看到了 随手试验一下 AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Objec ...
- SSM-1第一章 认识SSM框架和Redis
第一章 认识SSM框架和Redis 1.1 Spring框架 Sring理念 Ioc 控制反转 IOC是一个容器,在Spring中,它会认为一切Java资源都是JavaBean,容器的目标是 ...
- spring第一章
spring第一章 一.概述 Spring是一个开源框架,它由Rod Johnson创建.它是为了解决企业应用开发的复杂性而创建的.Spring使用基本的JavaBean来完成以前只可能由EJB完成的 ...
- Java开发工程师(Web方向) - 04.Spring框架 - 第3章.AOP技术
第3章--AOP技术 Spring框架 - AOP概述 笔记https://my.oschina.net/hava/blog/758873Spring框架 - AOP使用 笔记https://my.o ...
- Spring实战第一章学习笔记
Spring实战第一章学习笔记 Java开发的简化 为了降低Java开发的复杂性,Spring采取了以下四种策略: 基于POJO的轻量级和最小侵入性编程: 通过依赖注入和面向接口实现松耦合: 基于切面 ...
- Spirng学习指南-第一章(完)
Spring学习指南 内容提要 Spring框架是以简化J2EE应用程序开发为特定目标而创建的,是当前最流行的Java开发框架. 本书从介绍Spring框架入手,针对Spring4.3和Jav ...
- 第05章 AOP细节
第05章 AOP细节 1.切入点表达式 1.1 作用 通过表达式的方式定位一个或多个具体的连接点. 1.2 语法细节 ①切入点表达式的语法格式 execution([权限修饰符] [返回值类型] [简 ...
- 《Django By Example》第一章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:本人目前在杭州某家互联网公司工作, ...
- MyBatis3.2从入门到精通第一章
第一章一.引言mybatis是一个持久层框架,是apache下的顶级项目.mybatis托管到goolecode下,再后来托管到github下.(百度百科有解释)二.概述mybatis让程序将主要精力 ...
随机推荐
- Codeforces Round #475 (Div. 2) D. Destruction of a Tree
题意:给你一棵树, 只能删度数为偶数的点, 问你能不能将整个图删完, 如果能输入删除的顺序. 思路:对于一棵树来说, 如果里面的点的个数是偶数个则肯定不可能, 偶数个点有奇数条边,而你每次删只能删偶数 ...
- 应用Mongoose开发MongoDB(1)数据库连接
最近因为项目,接触了MongoDB,因为是分工合作,我负责的部分主要是实现前端对数据库增删查改的需求,因此以下内容只着重于针对不同问题如何进行解决. 整个工程的最终目的是通过mongoose编写数据库 ...
- android 地图
========= Y:\AMap_Android_API_3DMap_Demo\android_studio\AMap3DDemo>keytool -v -list -keystore C:\ ...
- Jindent——让intellij idea 像eclipse一样生成模版化的javadoc注释
插件地址 http://plugins.jetbrains.com/plugin/2170?pr=idea 安装方法参考 http://www.cnblogs.com/nova-/p/3535636. ...
- BZOJ.3673/3674.可持久化并查集(可持久化线段树 按秩合并/启发式合并)
BZOJ 3673 BZOJ 3674(加强版) 如果每次操作最多只修改一个点的fa[],那么我们可以借助可持久化线段树来O(logn)做到.如果不考虑找fa[]的过程,时空复杂度都是O(logn). ...
- BZOJ.2806.[CTSC2012]Cheat(广义后缀自动机 DP 单调队列)
题目链接 首先二分答案L.然后就是判断能否将原串划分出一些长度不小于L的子串,这些子串要是给定n个串中的某个串的子串,且满足它们的长度之和不小于原串长度的90%. 贪心多长选一段什么的显然不对.老老实 ...
- js的sort()方法
说明 如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序.要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较. arra ...
- Mysql_解决The total number of locks exceeds the lock table size错误
在操作mysql数据库表时出现以下错误. 网上google搜索相关问题,发现一位外国牛人这么解释: If you're running an operation on a large number o ...
- 【汇总】PHP-FPM 配置优化(转)
-----------------------开启php-fpm慢脚本日志 request_slowlog_timeout = 30sslowlog = /usr/local/php/var/log/ ...
- jstat命令 -- Java虚拟机监控统计工具
http://blog.sina.com.cn/s/blog_5f5716580100u76r.html 语法:jstat [generalOption | outputOptions vmid [i ...