代理模式

1 静态代理
在代理模式(Proxy Pattern)中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式

主要解决
在直接访问对象时带来的问题,比如说:要访问的对象在远程的机器上。在面向对象系统中,有些对象由于某些原因(比如对象创建开销很大,或者某些操作需要安全控制,或者需要进程外的访问),直接访问会给使用者或者系统结构带来很多麻烦,我们可以在访问此对象时加上一个对此对象的访问层

优点: 1、职责清晰。 2、高扩展性。 3、智能化。

缺点: 1、由于在客户端和真实主题之间增加了代理对象,因此有些类型的代理模式可能会造成请求的处理速度变慢。 2、实现代理模式需要额外的工作,有些代理模式的实现非常复杂。

使用场景:按职责来划分,通常有以下使用场景: 1、远程代理。 2、虚拟代理。 3、Copy-on-Write 代理。 4、保护(Protect or Access)代理。 5、Cache代理。 6、防火墙(Firewall)代理。 7、同步化(Synchronization)代理。 8、智能引用(Smart Reference)代理。

注意事项:
1、和适配器模式的区别:适配器模式主要改变所考虑对象的接口,而代理模式不能改变所代理类的接口。
2、和装饰器模式的区别:装饰器模式为了增强功能,而代理模式是为了加以控制

实现
在这里插入图片描述

package proxy.staticproxy;

public interface Rent {

    void rent();
}

ackage proxy.staticproxy;

public class Houser implements Rent{
    @Override
    public void rent() {
        System.out.println("房东出租房间");
    }
}

package proxy.staticproxy;


public class ProxyRent implements Rent{

    private Rent rent;

    public ProxyRent(Rent rent) {
        this.rent = rent;
    }

    @Override
    public void rent() {
        seeHouse();
        rent.rent();
        ding();
    }

    public void seeHouse(){
        System.out.println("看房间");
    }

    public void ding(){
        System.out.println("签订合同");
    }

}

package proxy.staticproxy;

public class Test {
    public static void main(String[] args) {
        Houser houser = new Houser();

        ProxyRent proxyRent = new ProxyRent(houser);

        proxyRent.rent();
    }
}

2 动态代理
在这里插入图片描述

package proxy.dynamicproxy;

public interface Rent {
    void rent();
}

package proxy.dynamicproxy;

public class Houser implements Rent{
    @Override
    public void rent() {
        System.out.println("动态  房东租房");
    }
}

package proxy.dynamicproxy;

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

public class ProxyInvocationHandler implements InvocationHandler {

    private Rent rent;

    // 传入需要代理的接口
    public void setRent(Rent rent) {
        this.rent = rent;
    }

    // 根据不同的接口(类),动态生成不同的代理类
    public Object getProxy(){
        Object instance = Proxy.newProxyInstance(this.getClass().getClassLoader(),
                rent.getClass().getInterfaces(),
                this);

        return instance;
    }

    // 使用反射,调用被代理类的方法   method.invoke(rent, objects)
    @Override
    public Object invoke(Object o, Method method, Object[] objects) throws Throwable {

        seeHouse();
        Object res = method.invoke(rent, objects);
         ding();
        return res;
    }



    public void seeHouse(){
        System.out.println("看房子");
    }
    public void  ding(){
        System.out.println("签协议");
    }
}

package proxy.dynamicproxy;

public class Test {
    public static void main(String[] args) {
        Houser houser = new Houser();

        ProxyInvocationHandler handler = new ProxyInvocationHandler();
        handler.setRent(houser);

        Rent proxy = (Rent) handler.getProxy();

        proxy.rent();

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值