代理模式
1.代理需要实现和被代理者相同的接口。只有实现了相同的接口。代理者才能和被代理者看起来一模一样。
2.代理者在完成目标方法之外 还要完成其他的工作。
静态代理模式
静态代理模式需要实现与被代理者相同的接口,为了看起来和目标对象一样 需要修改ID
静态代理模式中包含了
1、目标对象
2、在目标对象完成操作之外 完成额外的工作
好处:
实现了代码的分离。让业务层代码只处理业务。事务代码只处理事务,两者松耦合。
缺点:
事务添加的代码重复,复用性不好。基本不用。
JDK的代理
能够解决重复代码的编写,并且继承了静态代理的所有的优点。
缺点:
1.所有的方法都添加上了事务。这样做不合理。
2.动态代理的局限性高,不能做到灵活的运用。
3.target.getClass().getInterfaces() 要求被代理者必须实现接口。这样才能创建出代理对象
Cglib动态代理模式
特点:将来生成的代理对象都是目标对象的子类。 无论目标对象是否有接口,都能生成代理对象。
spring底层用CGlib和JDK的动态代理帮我们生成代理对象,方式更加的灵活
AOP
切面(Aspect)
连接点(Joinpoint)
通知(Advice)
切入点(Pointcut)
目标对象(Target Object)
AOP代理(AOP Proxy)
织入(Weaving)
通知的类型
1.aop:before 前置通知 在目标方法执行之前 要执行的。
2.aop:around 环绕通知 在目标方法执行之前和执行之后都需要执行的通知
3.aop:after-returning 后置通知 在目标方法执行之后 再执行的通知。
4.aop:after-throwing 异常通知 当执行目标方法之后 抛出异常 才执行异常通知。
5.aop:after method 最终通知 finally 最后肯定会被执行的通知。
Spring声明式的事务处理的意义:
将来我们程序员自己无需手动的维护事务。都交给spring来完成。
1.代理需要实现和被代理者相同的接口。只有实现了相同的接口。代理者才能和被代理者看起来一模一样。
2.代理者在完成目标方法之外 还要完成其他的工作。
静态代理模式
静态代理模式需要实现与被代理者相同的接口,为了看起来和目标对象一样 需要修改ID
静态代理模式中包含了
1、目标对象
2、在目标对象完成操作之外 完成额外的工作
好处:
实现了代码的分离。让业务层代码只处理业务。事务代码只处理事务,两者松耦合。
缺点:
事务添加的代码重复,复用性不好。基本不用。
JDK的代理
能够解决重复代码的编写,并且继承了静态代理的所有的优点。
缺点:
1.所有的方法都添加上了事务。这样做不合理。
2.动态代理的局限性高,不能做到灵活的运用。
3.target.getClass().getInterfaces() 要求被代理者必须实现接口。这样才能创建出代理对象
Cglib动态代理模式
特点:将来生成的代理对象都是目标对象的子类。 无论目标对象是否有接口,都能生成代理对象。
spring底层用CGlib和JDK的动态代理帮我们生成代理对象,方式更加的灵活
AOP
切面(Aspect)
连接点(Joinpoint)
通知(Advice)
切入点(Pointcut)
目标对象(Target Object)
AOP代理(AOP Proxy)
织入(Weaving)
通知的类型
1.aop:before 前置通知 在目标方法执行之前 要执行的。
2.aop:around 环绕通知 在目标方法执行之前和执行之后都需要执行的通知
3.aop:after-returning 后置通知 在目标方法执行之后 再执行的通知。
4.aop:after-throwing 异常通知 当执行目标方法之后 抛出异常 才执行异常通知。
5.aop:after method 最终通知 finally 最后肯定会被执行的通知。
Spring声明式的事务处理的意义:
将来我们程序员自己无需手动的维护事务。都交给spring来完成。