JavaSE|代理设计模式

文章目录

代理设计模式:两个子类共同实现一个接口,其中一个子类负责真实业务实现,另一个子类完成辅助真实业务主题的操作。简单来说就是在不改变源码的情况下,实现对目标对象的功能扩展。

不如说有一个歌手对象叫Singer,这个对象有一个唱歌方法叫做sing().

class Singer{
public void sing(){
System.out.println("唱一首歌");
    }  
 }

假如你希望,通过你的某种方式生产出来的歌手对象,在唱歌前后还要想观众问好和答谢,也即对目标对象Singer的sing方法进行功能扩展。

class Singer{
public void sing(){
  System.out.println("向观众问好");
  System.out.println("唱一首歌");
  System.out.println("谢谢大家");
    }  
 }

但是现在要求你不能直接对源代码进行修改,你会怎么来实现这个功能呢?这个时候就需要用到Java中的代理模式了。

静态代理模式

范例:

 interface ISinger{
     void sing();
 }
/**
 * 目标对象实现第一个接口
 */
class Singer implements ISinger{
    @Override
    public void sing() {
        System.out.println("唱一首歌...");
    }
}

/**
 *代理对象和目标对象实现相同的接口
 */
class SingerProxy implements ISinger{
    private ISinger target;//接收目标对象,以便调用sing()
    public SingerProxy(ISinger target){
        this.target=target;
    }
    public void sayHello() {
        System.out.println("向观众问好...");
    }
     public void sayThanks() {
         System.out.println("谢谢大家...");
    }
    //将目标对象的sing()进行功能扩展
    @Override
    public void sing() {
        sayHello();
        target.sing();
         sayThanks();
    }
}
 public class test {

    public static void main(String[] args) {

        ISinger singer=new Singer();
        SingerProxy singerProxy=new SingerProxy(singer);
        singerProxy.sing();
    }
}

其实这里做的事情无非就是创建了一个代理类SingerProxy,继承了ISinger接口并实现了其中的方法。只不过这种实现特意包含了目标对象的方法,正是这种特征使得看起来像是“扩展”了目标对象的方法。假使代理对象中只是简单地对sing方法做了另一种实现而没有包含目标对象的方法,也就不能算作代理模式了。所以这里的包含是关键。

多线程中Thread类:负责辅助真实业务操作
自定义线程类(实现Runnable接口):负责真实业务的实现
就是一个代理模式

缺点:代理对象必须提前写出,如果接口层发生了变化,代理对象的代码也要进行维护。

发布了87 篇原创文章 · 获赞 73 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/HL_HLHL/article/details/88621666