代理模式【java版】

应用场景:
       安全代理:控制对原对象的访问权限
                注: 之所以把权限控制放在"代理类"中,而不是放在原对象中,主要依据"单一性原则".
       远程代理:网络通讯时,将加密,解密,打包,解包这些操作一起封装在"代理对象"使得客户端
                  调用时,就像是在访问本地数据.
                  eg: WebService的工作原理
       虚拟代理:当存在实例化需要很长时间的成员对象时,当需要调用到与该对象相关的方法时才
                  声明该对象,并实例化.
       智能指引:未使用过

基本特点: 代理拥有实际执行者的实例,代理的每一个函数,直接调用实际执行者对应的函数.

一、普通代理:

       (安全代理)

       1.原始接口

//原始类方法接口
public interface Subject {
public void readFile(String fileName);
public void writeFile(String fileName);
}

       2.原始类

//原始类:实现原始接口中的方法
public class RealSubject implements Subject {

public void readFile(String fileName) {
System.out.println("进行读取文件操作!");

}

public void writeFile(String fileName) {
System.out.println("进行文件写入操作!");

}

}

       3.代理类

public class Proxy implements Subject {
private Subject subject;
private boolean isReadable;
private boolean isWriteable;
//创建“代理对象”时,传入权限参数
public Proxy(Subject subject,boolean isReadable,boolean isWriteable) {
this.subject=subject;
this.isReadable=isReadable;
this.isWriteable=isWriteable;
}

public void readFile(String fileName) {
if(isReadable){
subject.readFile(fileName);
}else{
System.out.println("对不起,您没有文件读取权限!");
}

}

public void writeFile(String fileName) {
if(isWriteable){
subject.writeFile(fileName);
}else{
System.out.println("对不起,您没有写文件权限!");
}

}

}

       4.测试

       测试代码:

public class Main {

public static void main(String[] args) {
System.out.println("开始测试代理模式。。。");
System.out.println();

Proxy theProxy=new Proxy(new RealSubject(),true,false);

theProxy.readFile(new String("mytext"));
theProxy.writeFile(new String("mytext"));

}

}

       运行结果:


二、动态代理

 

 

三、代理模式与适配器模式,装饰模式的比较

    代理模式:   接口不变
    适配器模式: 接口改变
    
    代理模式: 控制对象的访问
    装饰者模式:动态多次添加装饰

    相同点:都封装对象
    不同点:
           代理模式:不改变外部调用的接口,只是原来对象的一个替身,控制对象,外界必须通过

                       代理才能使用被封装的对象.
           装饰模式:不改变外部调用的接口,通过新增私有方法对原接口功能进行增强
           适配器模式:改变外部调用的接口

posted @ 2011-12-30 16:56  edisonfeng  阅读(526)  评论(1编辑  收藏  举报