我对AOP的理解
1、问题

问题:想要添加日志记录、性能监控、安全监测
2、最初解决方案
2.1、最初解决方案

2.2、抽象类进行共性设计,子类进行个性设计,此处不讲解,缺点一荣俱荣,一损俱损
2.3、使用装饰器模式/代理模式改进的解决方案

- public class MyInvocationHandler implements InvocationHandler {
 - private Object target;
 - public MyInvocationHandler(Object target) {
 - this.target = target;
 - }
 - @Override
 - public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
 - //1.记录日志 2.时间统计开始 3.安全检查
 - Object retVal = method.invoke(target, args);
 - //4.时间统计结束
 - return retVal;
 - }
 - public static Object proxy(Object target) {
 - return Proxy.newProxyInstance(target.getClass().getClassLoader(),
 - target.getClass().getInterfaces(), new MyInvocationHandler(target));
 - }
 - }
 
编程模型
- //proxy 在其上调用方法的代理实例
 - //method 拦截的方法
 - //args 拦截的参数
 - Override
 - public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
 - Object retVal=null;
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("你没有权限");
 - }
 - else {//反射调用目标对象的某个方法
 - retVal = method.invoke(target, args);
 - }
 - //后处理
 - return retVal;
 - }
 
缺点:使用麻烦,不能代理类,只能代理接口
- public class MyInterceptor implements MethodInterceptor {
 - private Object target;
 - public MyInterceptor(Object target) {
 - this.target = target;
 - }
 - @Override
 - public Object intercept(Object proxy, Method method, Object[] args,
 - MethodProxy invocation) throws Throwable {
 - //1.记录日志 2.时间统计开始 3.安全检查
 - Object retVal = invocation.invoke(target, args);
 - //4.时间统计结束
 - return retVal;
 - }
 - public static Object proxy(Object target) {
 - return Enhancer.create(target.getClass(), new MyInterceptor(target));
 - }
 - }
 
编程模型
- //proxy 在其上调用方法的代理实例 method拦截的方法 args 拦截的参数
 - //invocation 用来去调用被代理对象方法的
 - @Override
 - public Object intercept(Object proxy, Method method, Object[] args,
 - MethodProxy invocation) throws Throwable {
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("出错了");
 - }
 - else {//调用目标对象的某个方法
 - Object retVal = invocation.invoke(target, args);
 - }
 - //后处理
 - return retVal;
 - }
 
动态代理本质


- @Aspect
 - public class PayEbiAspect {
 - @Pointcut(value="execution(* pay(..))")
 - public void pointcut() {}
 - @Around(value="pointcut()")
 - public Object around(ProceedingJoinPoint pjp) throws Throwable {
 - //1.记录日志
 - //2.时间统计开始
 - //3.安全检查
 - Object retVal = pjp.proceed();//调用目标对象的真正方法
 - //4.时间统计结束
 - return retVal;
 - }
 - }
 
- //2 切入点
 - @Pointcut(value="execution(* *(..))")
 - public void pointcut() {}
 - //3 拦截器的interceptor
 - @Around(value="pointcut()")
 - public Object around(ProceedingJoinPoint pjp) throws Throwable {
 - Object retVal=null;
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("你没有权限");
 - }
 - else {//调用目标对象的某个方法
 - retVal = pjp.proceed();
 - }
 - //后处理
 - return retVal;
 - }
 

·代码纠结/混乱——当一个模块或代码段同时管理多个关注点时发生这种情况。
·代码分散——当一个关注点分布在许多模块中并且未能很好地局部化和模块化时发生这种情况 。
AOSD中文版--基于用例的面向方面软件开发
1、问题

问题:想要添加日志记录、性能监控、安全监测
2、最初解决方案
2.1、最初解决方案

2.2、抽象类进行共性设计,子类进行个性设计,此处不讲解,缺点一荣俱荣,一损俱损
2.3、使用装饰器模式/代理模式改进的解决方案

- public class MyInvocationHandler implements InvocationHandler {
 - private Object target;
 - public MyInvocationHandler(Object target) {
 - this.target = target;
 - }
 - @Override
 - public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
 - //1.记录日志 2.时间统计开始 3.安全检查
 - Object retVal = method.invoke(target, args);
 - //4.时间统计结束
 - return retVal;
 - }
 - public static Object proxy(Object target) {
 - return Proxy.newProxyInstance(target.getClass().getClassLoader(),
 - target.getClass().getInterfaces(), new MyInvocationHandler(target));
 - }
 - }
 
编程模型
- //proxy 在其上调用方法的代理实例
 - //method 拦截的方法
 - //args 拦截的参数
 - Override
 - public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
 - Object retVal=null;
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("你没有权限");
 - }
 - else {//反射调用目标对象的某个方法
 - retVal = method.invoke(target, args);
 - }
 - //后处理
 - return retVal;
 - }
 
缺点:使用麻烦,不能代理类,只能代理接口
- public class MyInterceptor implements MethodInterceptor {
 - private Object target;
 - public MyInterceptor(Object target) {
 - this.target = target;
 - }
 - @Override
 - public Object intercept(Object proxy, Method method, Object[] args,
 - MethodProxy invocation) throws Throwable {
 - //1.记录日志 2.时间统计开始 3.安全检查
 - Object retVal = invocation.invoke(target, args);
 - //4.时间统计结束
 - return retVal;
 - }
 - public static Object proxy(Object target) {
 - return Enhancer.create(target.getClass(), new MyInterceptor(target));
 - }
 - }
 
编程模型
- //proxy 在其上调用方法的代理实例 method拦截的方法 args 拦截的参数
 - //invocation 用来去调用被代理对象方法的
 - @Override
 - public Object intercept(Object proxy, Method method, Object[] args,
 - MethodProxy invocation) throws Throwable {
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("出错了");
 - }
 - else {//调用目标对象的某个方法
 - Object retVal = invocation.invoke(target, args);
 - }
 - //后处理
 - return retVal;
 - }
 
动态代理本质


- @Aspect
 - public class PayEbiAspect {
 - @Pointcut(value="execution(* pay(..))")
 - public void pointcut() {}
 - @Around(value="pointcut()")
 - public Object around(ProceedingJoinPoint pjp) throws Throwable {
 - //1.记录日志
 - //2.时间统计开始
 - //3.安全检查
 - Object retVal = pjp.proceed();//调用目标对象的真正方法
 - //4.时间统计结束
 - return retVal;
 - }
 - }
 
- //2 切入点
 - @Pointcut(value="execution(* *(..))")
 - public void pointcut() {}
 - //3 拦截器的interceptor
 - @Around(value="pointcut()")
 - public Object around(ProceedingJoinPoint pjp) throws Throwable {
 - Object retVal=null;
 - //预处理
 - //前置条件判断
 - boolean ok = true;
 - if(!ok) {//不满足条件
 - throw new RuntimeException("你没有权限");
 - }
 - else {//调用目标对象的某个方法
 - retVal = pjp.proceed();
 - }
 - //后处理
 - return retVal;
 - }
 

·代码纠结/混乱——当一个模块或代码段同时管理多个关注点时发生这种情况。
·代码分散——当一个关注点分布在许多模块中并且未能很好地局部化和模块化时发生这种情况 。
AOSD中文版--基于用例的面向方面软件开发
我对AOP的理解的更多相关文章
- 对IOC和DI以及AOP的理解
		
为了理解Spring的IoC与DI从网上查了很多资料,作为初学者,下面的描述应该是最详细,最易理解的方式了. 首先想说说IoC(Inversion of Control,控制倒转).这是spring的 ...
 - AOP 怎么理解?
		
什么是 AOP ? AOP 为 Aspect Oriented Programming 的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.AOP 是 OOP ...
 - Spring AOP深入理解之拦截器调用
		
Spring AOP深入理解之拦截器调用 Spring AOP代理对象生成回想 上一篇博客中:深入理解Spring AOP之二代理对象生成介绍了Spring代理对象是怎样生成的,当中重点介绍了JDK动 ...
 - Spring框架学习(9)AOP技术理解与使用
		
内容源自:AOP技术理解与使用 一.什么是AOP? aop技术是面向切面编程思想,作为OOP(面向对象编程)的延续思想添加到企业开发中,用于弥补OOP开发过程中的缺陷而提出的编程思想. AOP底层也是 ...
 - Spring 的 IOC 和 AOP 的理解
		
Spring 的 IOC 和 AOP 的理解: https://www.jianshu.com/p/bf1adc3b75e6 对Spring的核心(AOP和IOC)的理解(大白话) https://w ...
 - 谈谈对AOP的理解
		
Aspect Oriented Programming 面向切面编程.解耦是程序员编码开发过程中一直追求的.AOP也是为了解耦所诞生. 具体思想是:定义一个切面,在切面的纵向定义处理方法,处理完成之 ...
 - 关于Spring中AOP的理解
		
AOP简介[理解][重点] 1.AOP(Aspect Oriented Programing)面向切面/方面编程 2.AOP隶属软件工程的范畴,指导开发人员如何制作开发软件,进行结构设计 3.AOP联 ...
 - 对Spring IOC和AOP的理解
		
控制反转(IOC)是什么?(理解好Ioc的关键是要明确"谁控制谁,控制什么,为何是反转(有反转就应该有正转了),哪些方面反转了") 1.Ioc-Inversion of Contr ...
 - Spring AOP概念理解
		
1.我所知道的aop 初看aop,上来就是一大堆术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等.一下子让你不知所措,心想着:怪不得很多人都和我说aop多难多难.当我看进去以后 ...
 
随机推荐
- Android 四种常见的线程池
			
引入线程池的好处 1)提升性能.创建和消耗对象费时费CPU资源 2)防止内存过度消耗.控制活动线程的数量,防止并发线程过多. 我们来看一下线程池的简单的构造 public ThreadPoolExec ...
 - SSH深度历险(五) 深入浅出-----IOC AND AOP
			
IOC就是Inversion of Control,控制反转.在Java开发中,IoC意味着将你设计好的类交给系统(容器)来控制实现,而不是在你的类内部控制.这称为控制反转. 本人理解:就是把原本你自 ...
 - 每个程序员都应该用MBP
			
换笔记本的想法很久了,前段时间换工作就想看换工作之后是什么情况吧.可能工作配的笔记本就是MBP.后来发现是想多了,新工作的笔记本是Thinkpad X240, 配置完全够用了,8G内存+128G的FL ...
 - linux后台运行程序(secureCRT断掉或关闭后继续运行程序)
			
secureCRT断掉后想继续运行程序.也就是程序会在后台一直执行到结束. secureCRT通过ssh联接到client端运行程序,如果关掉窗口或者断开连接时,任务会被kill. 为了程序能够后台执 ...
 - 【Unity Shaders】Lighting Models —— 衣服着色器
			
本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源 ...
 - Linux之命令的组合
			
在Linux下有好多经典的操作,其中尤为经典的是命令的组合,不管是作为参数,还是命令之间的配合,都做得比较完善.下面看一下常用的一些命令吧. 1.连续运行多个命令就可以使用':'作为分隔,但是缺点就是 ...
 - Dynamics CRM2013  任务列表添加自定义按钮
			
任务列表的command bar 上面添加自定义按钮如下 要注意的是此处的列表不是任务实体而是活动实体,如果你是在任务实体的home栏上面加那你永远看不见按钮的显示,但如果是要在任务的表单界面上加按钮 ...
 - Linux IPC实践(3) --具名FIFO
			
FIFO具名/命名管道 (匿名)管道应用的一个限制就是只能在具有共同祖先(具有亲缘关系)的进程间通信. 如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道;命 ...
 - 总账:日记账导入流程(文档 ID 1591640.1)
			
文档内容 概要 历史记录 详细信息 GL_INTERFACE_CONTROL GL_INTERFACE_HISTORY GL_IMPORT_REFERENCES 摘要 ...
 - 《java入门第一季》之LinkList模拟桟结构案例
			
需求:请用LinkedList模拟栈数据结构的集合,并测试 题目的意思是: 你自己的定义一个集合类,在这个集合类内部可以使用LinkedList模拟. 定义一个类叫MyStack代码如下: packa ...