jdk动态代理
实现原理:利用字节码技术,生成新的class文件,来达到动态代理效果。
新的class文件是怎么组织的?由于代理目标是接口,则通过实现接口和继续代理类来完成。看看下面的例子更容易明白。
demo 接口
public interface PeoPleInterface {
    void say() throws Throwable;
}
实现类
public class GrilPeoPle implements PeoPleInterface {
    @Override
    public void say() {
        System.out.println("女人说");
    }
}
代理类
public class PeoPleInvacationHandler implements InvocationHandler {
    private Object obj;
    public PeoPleInvacationHandler(Object obj) {
        this.obj = obj;
    }
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("人类开始");
        Object invoke = method.invoke(obj, args);
        System.out.println("人类结束");
        return invoke;
    }
}
最终产生的类。这个类就是$Proxy0的实现原理。这个类是通过字节码生成的。
public class PeoPleProxy extends PeoPleInvacationHandler implements PeoPleInterface {
    public PeoPleProxy(Object obj) {
        super(obj);
    }
    @Override
    public void say() throws Throwable {
        // 调用目标方法
        super.invoke(this,PeoPleInterface.class.getMethod("say",null),null);
    }
    public static void main(String[] args) {
        PeoPleInterface grilPeoPle = new GrilPeoPle();
        PeoPleProxy proxy =new PeoPleProxy(grilPeoPle);
        try {
            proxy.say();
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }
    }
}
cglib动态代理
cglib 是代理类的,针对于jdk只能代理接口的问题。原理也是通过继承来重新父类方法,才能达到重写的效果。
 
  
  
 