静态代理与动态代理

概念:

代理模式--是一种设计模式,分为静态代理和动态代理
类似于装饰模式,都是在不改变原来类增强原来类的功能
静态代理:继承父类,重写父类方法,在父类方法前后做操作
静态代理的缺点:对于类过多的情况下,会生成过多的代理

静态代理测试:

package staticproxy;

public class Bird {
    public void fly(){
        System.out.println("i am fly");
    }
}
package staticproxy;
//代理模式--是一种设计模式,分为静态代理和动态代理
//类似于装饰模式,都是在不改变原来类增强原来类的功能
//静态代理:继承父类,重写父类方法,在父类方法前后做操作
//静态代理的缺点:对于类过多的情况下,会生成过多的代理
public class BirdProxy extends Bird {
    @Override
    public void fly() {
        System.out.println("i am sing");
        super.fly();
        System.out.println("i am dance");
    }
}

动态代理测试:

package dynamicProxy;

public interface Fly {
    void fly();
    void eat();
}
package dynamicProxy;

public class Bird implements Fly {
    public void fly() {
        System.out.println("bird can fly");
    }

    public void eat() {
        System.out.println("bird can eat");
    }
}
package dynamicProxy;

public class Pig implements Fly {
    public void fly() {
        System.out.println("pig can fly");
    }
    public void eat() {
        System.out.println("bird can eat");
    }
}
package dynamicProxy;

import java.lang.reflect.Proxy;

//动态代理:动态生成代理类
public class DynamicProxyDemo {
    public static void main(String[] args) {
        //生成代理实例
        //获取类加载器
        ClassLoader classLoader = Fly.class.getClassLoader();
        //被代理类的接口
        Class[] interfaces = {Fly.class};
        //代理处理类
        ProxyHandler proxyHandler = new ProxyHandler(new Pig());
        //生成真正的代理类
        Fly pigProxy = (Fly) Proxy.newProxyInstance(classLoader, interfaces, proxyHandler);
        //当调用被代理类的方法时,会自动进入invoke方法
        pigProxy.fly();
        pigProxy.eat();
        /*ProxyHandler proxyHandler2 = new ProxyHandler(new Bird());
        //生成真正的代理类
        Fly birdProxy = (Fly) Proxy.newProxyInstance(classLoader, interfaces, proxyHandler2);
        //当调用被代理类的方法时,会自动进入invoke方法
        birdProxy.fly();*/

    }
}
package dynamicProxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

/**
 * InvocationHandler:调用处理器
 * 在其中实现代理逻辑
 */
public class ProxyHandler implements InvocationHandler {
    //运用构造方法传参
    //private Object proxy;
    //被代理类(接口)
    private Fly proxied;

    public ProxyHandler(Fly proxied) {
        this.proxied = proxied;
    }

    //当调用被代理类的方法时,会自动进入invoke方法
    //如:被代理类是Bird,方法时fly
    //proxy:表示代理类--pig
    //Method:被调用的方法--fly
    //args:表示方法参数---空
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("i can sing");
        //反射--传值
        method.invoke(this.proxied,args);
        System.out.println("i can dance");
        return null;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

脸ル粉嘟嘟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值