文章目录
代理设计模式:两个子类共同实现一个接口,其中一个子类负责真实业务实现,另一个子类完成辅助真实业务主题的操作。简单来说就是在不改变源码的情况下,实现对目标对象的功能扩展。
不如说有一个歌手对象叫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接口):负责真实业务的实现
就是一个代理模式
缺点:代理对象必须提前写出,如果接口层发生了变化,代理对象的代码也要进行维护。