代理模式

即Proxy Pattern,23种 java 常用 设计模式 之一。代理模式的定义:为其他对象提供一种 代理 以控制对这个对象的访问。在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在 客户端 和目标对象之间起到中介的作用。

模式结构:

一个是真正的你要访问的对象(目标类),一个是代理对象,真正对象与代理

 


  对象实现同一个接口,先访问代理类再访问真正要访问的对象。

代码示例

假设有一个Italk接口,有空的方法talk()(说话),所有的Person对象都实现(implements)这个接口,实现talk()方法,前端有很多地方都将Person实例化,执行talk方法, 后来发现这些前端里有一些除了要说话以外还要唱歌(sing),那么我们既不能在Italk接口里增加sing()方法,又不能在每个前端都增加sing方法,我们只有增加一个代理类TalkProxy,这个代理类里实现talk和sing方法,然后在需要sing方法的客户端调用代理类即可,代码如下:

接口类Italk

public interface Italk {
public void talk(String msg);
}

实现类people

public class People implements Italk {
public String username;
public String age;
public String getName() {
return username;
}
public void setName(String name) {
this.username= name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public People(String name1, String age1) {
this.username= name1;
this.age = age1;
}
public void talk(String msg) {
System.out.println(msg+"!你好,我是"+username+",我年龄是"+age);
}
}

代理类TalkProxy

public class TalkProxy implements Italk {
private Italk talker;
public TalkProxy (Italk talker) {
//super();
this.talker=talker;
}
public void talk(String msg) {
talker.talk(msg);
}
public void talk(String msg,String singname) {
talker.talk(msg);
sing(singname);     //增加sing方法
}
private void sing(String singname){
System.out.println("唱歌:"+singname);
}
}

应用端MyProxyTest

public class MyProxyTest {
/**代理模式的测试
* @param args
*/
public static void main(String[] args) {
//不需要执行额外方法的
People person=new People("王云浩","20");
person.talk("No ProXY Test");
//需要执行额外方法的
TalkProxy talker=new TalkProxy(person);
talker.talk("ProXY Test","行百里者半九十");
}
}
个人总结:
1、代理类处于客户端与目标操作类之间
2、客户端操作的是代理类,代理类操作目标类
3、代理类的作用是增加了目标类没有的一些操作方法。






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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值