代理模式
各路的明星都会有个自己的经纪人来替自己打点各种各样的事情
JDK静态代理
代理类中持有一个被代理类的实例,通过被代理类实例调用被代理对象的方法
另外在方法前后均可加入其它的处理逻辑
public class UserDaoProxy implements IUserDao {
private UserDao ud = new UserDao();
@Override
public void save() {
System.out.println("代理操作,开启事务");
ud.save();
System.out.println("代理操作,关闭事务");
}
@Override
public void find() {
System.out.println("代理操作,开启事务");
ud.find();
System.out.println("代理操作,关闭事务");
}
}
AspectJ静态代理
AspctJ就是用特定的编译器和语法,对类实现编译期增强,实现静态代理技术
CGLIB动态代理
public interface AopProxy {
Object getProxy();
Object getProxy(@Nullable ClassLoader classLoader);
}
如果目标对象没有实现了接口,必须采用CGLIB库,spring会自动在JDK动态代理和CGLIB之间转换。
它采用的是继承被代理类,使用其子类的方式,弥补了被代理类没有接口的不足
被代理类不能是final的,因为final类无法被继承
class CglibAopProxy implements AopProxy, Serializable {
}
JDK动态代理
如果目标对象实现了接口,默认情况下会采用JDK的动态代理实现AOP。
如果目标对象实现了接口,可以强制使用CGLIB实现AOP。
反射机制。
final class JdkDynamicAopProxy implements AopProxy, InvocationHandler, Serializable {
}