2つのケースで、動的プロキシモデルを理解する

以前の静的プロキシモードに基づいて動的プロキシモードに変更されました

ケースワン

1.インターフェイス

//租房
public interface Rent {
    public void rent();
}

2.実際のキャラクター

//房东
public class Host implements Rent {
    public void rent(){
        System.out.println("房东出租房子!");
    }
}

3.プロキシクラスの自動生成InvocationHandlerはプロキシクラス
を自動的に生成し、このクラスを実装するクラスを作成します

public class ProxyInvocationHandler implements InvocationHandler {
    //被代理的按口
    private Rent rent;

    public void setRent(Rent rent) {
        this.rent = rent;
    }

    //生成得到代理类
    public Object getProxy() {
        return Proxy.newProxyInstance(this.getClass().getClassLoader(), rent.getClass().getInterfaces(), this);
    }

    //处理代理实例。并返回结果
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //动态代理的本质,就是使用反射机制实现!
        seeHouse();
        Object result = method.invoke(rent, args);
        fare();
        return result;
    }

    public void seeHouse() {
        System.out.println("中介带看房子");
    }

    public void fare() {
        System.out.println("收取中介费");
    }
}

4.顧客アクセス

public class Client {
    public static void main(String[] args) {
        //真实角色
        Host host = new Host();
        //代理角色:现在没有
        ProxyInvocationHandler pih = new ProxyInvocationHandler();
        //通过调用程序处理角色米处理我们要调用的按口对象!
        pih.setRent(host);
        Rent proxy = (Rent) pih.getProxy();//这里的proxy就是动态生成的,我们并没有写

        proxy.rent();
    }
}

事例2

1.インターフェイス

public interface UserService{
    void add();
    void delete();
    void update();
    void query();
}

2.実際のキャラクター

public class UserServiceImpl implements UserService {
    public void add() {
        System.out.println("增加了一个用户");
    }
    public void delete() {
        System.out.println("删除了一个用户");
    }

    public void update() {
        System.out.println("修改了一个用户");
    }
    public void query() {
        System.out.println("查询了一个用户");
    }
}

3.プロキシクラスを自動的に生成する

//等我们会用这个类, 自动生成代理类!
public class ProxyInvocationHandler implements InvocationHandler {
    //被代理的按口
    private Object target;

    public void setTarget(Object target) {
        this.target = target;
    }

    //生成得到代理类
    public Object getProxy() {
        return Proxy.newProxyInstance(this.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
    }

    //处理代理实例。并返回结果
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //动态代理的本质,就是使用反射机制实现
        log(method.getName());//反射得到实现的方法的名字
        Object result = method.invoke(target, args);

        return result;
    }

    public void log(String msg) {
        System.out.println("执行了" + msg + "方法");
    }
}

4.顧客アクセス

public class Client {
    public static void main(String[] args) {
        //真实角色
        UserServiceImpl userService = new UserServiceImpl();
        //代理角色,不存在
        ProxyInvocationHandler pih = new ProxyInvocationHandler();
        pih.setTarget(userService);
        //动态生成代理类
        UserService proxy = (UserService) pih.getProxy();
        
        proxy.query();
    }
}

まとめ

動的エージェントの利点:

  • 一部の公共事業に注意を払う必要なく、実際のキャラクターの操作をより純粋にすることができます
  • 公衆は代理人の役割に引き渡され、事業の分割を実現します
  • 公共サービス拡大時の便利な集中管理
  • 動的エージェントクラスエージェントクラスは、一般的にビジネスのクラスに対応するインターフェースです
  • 動的プロキシクラスは、同じインターフェイスが実装されている限り、複数のクラスをプロキシできます。
元の記事を51件公開 ・いい ね73 訪問数3700

おすすめ

転載: blog.csdn.net/qq_41256881/article/details/105438445