代理模式-go/java实现

栏目: Go · 发布时间: 5年前

内容简介:目的:在代理类中实现对操作目标类的控制,间接访问优点:中介隔离了一层,调用对象类的时候,不需要直接操作,而是由第三方的代理类操作,这样更有利于解耦,有高扩展性缺点:代码量增加,静态代理的每一个实体类的业务逻辑都需要有个对应代理类来完成。

目的:在代理类中实现对操作目标类的控制,间接访问

优点:中介隔离了一层,调用对象类的时候,不需要直接操作,而是由第三方的代理类操作,这样更有利于解耦,有高扩展性

缺点:代码量增加,静态代理的每一个实体类的业务逻辑都需要有个对应代理类来完成。

设计场景如下:

我们现在要通过中介买房,我们需要做的是看房,中介会完成帮我们跟业主沟通,挑选房子,带我们去看,拿钥匙开门,谈价格等等一系列工作,而我们需要做的就是看房子和付款。

静态代理——golang实现:

package proxypattern_static

import "fmt"

/*接口*/
type ISeller interface {
    /*定义接口实现方法*/
    deal(int)
}
/*代理类*/
type ProxySeller struct {
    seller Seller
}
/*实体类*/
type Seller struct {

}

/*代理类构造方法*/
func newProxySeller(seller Seller) *ProxySeller {
    return &ProxySeller{
        seller:seller,
    }
}
/*代理类实现接口及业务逻辑
    中介代替买家完成工作
*/
func (proxySeller ProxySeller) deal(money int) {
    if proxySeller.seller.deal(money) {
        proxySeller.seller.connectMoney(money)
        proxySeller.seller.transfer()
        fmt.Println("交易成功")
    } else {
        fmt.Println("交易失败")
    }
    fmt.Println("交易结束")
}

/*实体类实现接口
    卖家交易函数
 */
func (Seller) deal(money int) bool{
    if money > 100 {
        return true
    } else {
        return false
    }
}
/*实体类
    卖家收钱函数
*/
func (Seller) connectMoney(money int) {
    fmt.Println("卖家收到钱")
}

/*实体类
    卖家过户函数
*/
func (Seller) transfer(){
    fmt.Println("卖家过户")
}

func Excute(){
    proxySeller := newProxySeller(*new(Seller))
    proxySeller.deal(50)
    proxySeller.deal(200)
}

动态代理——java实现(后面学会 go 怎么实现再补充)

代理类实现InvocationHandler接口

public class ProxyHandler implements InvocationHandler {

    private Object object;

    public Object newProxyHandler(Object object) {
        this.object = object;
        return Proxy.newProxyInstance(object.getClass().getClassLoader(), object.getClass().getInterfaces(), this);
    }
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        // TODO Auto-generated method stub
        ISeller seller = (ISeller) this.object;
        if((boolean) method.invoke(this.object, args)) {
            System.out.println("交易成功");
            return true;
        } else {
            System.out.println("交易失败");
            return false;
        }
    }
}

接口

public interface Seller {
    public boolean deal(int price);
}

实现接口的实体类

public class ISeller implements Seller {

    @Override
    public boolean deal(int price) {
        // TODO Auto-generated method stub
        return price > 100 ? true : false;
    }
}

测试类

public class Main {

    public static void main(String args[]) {
        ProxyHandler proxyHandler = new ProxyHandler();
        Seller seller = (Seller) proxyHandler.newProxyHandler(new ISeller());
        seller.deal(200);
        seller.deal(50);
    }
}

动态代理多用来实现面向切面编程,也就是所谓的AOP


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

性能之巅

性能之巅

Brendan Gregg / 徐章宁、吴寒思、陈磊 / 电子工业出版社 / 2015-8-15 / 128

《性能之巅:洞悉系统、企业与云计算》基于Linux 和Solaris 系统阐述了适用于所有系统的性能理论和方法,Brendan Gregg 将业界普遍承认的性能方法、工具和指标收集于本书之中。阅读本书,你能洞悉系统运作的方式,学习到分析和提高系统与应用程序性能的方法,这些性能方法同样适用于大型企业与云计算这类最为复杂的环境的性能分析与调优。一起来看看 《性能之巅》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具