08、静态代理模式(Thread和Runnable底层实现机制)
/*
* 真实对象和代理对象都要实现同一个接口
* 代理对象要代理真实对象
* 好处:
* 代理对象可以做很多真实对象做不了的事情
* 真实对象专注做自己的事情
*/
public class StaticProxy {
public static void main(String[] args) {
WeddingCompany weddingCompany=new WeddingCompany(new YOU());
weddingCompany.HappyMarry();
new WeddingCompany(new YOU()).HappyMarry();
//类似的可以看出线程与runnable接口底部实现也是代理模式
//new Thread(() -> System.out.println("开心")).start();
// new Thread(new Runnable() {Runnable接口中只有一个抽象方法,可以简化成Lamda表达式
// @Override
// public void run() {
//
// }
// }).start();
new Thread(()-> System.out.println("这就开启线程了哦")).start();
}
}
//结婚接口
interface Marry{
void HappyMarry();
}
//真实结婚,你去结婚(实现接口类)
class YOU implements Marry{
@Override
public void HappyMarry() {
System.out.println("结婚了,超开心");
}
}
//代理角色,帮你结婚(实现接口类但要求传递接口对象参数”即Marry的接口的实现对象-->此处指YOU对象“)
class WeddingCompany implements Marry{
private Marry target;//代理的目标对象
public WeddingCompany(Marry target) {
this.target = target;
}
@Override//代理接口实现的接口方法实际是调用真实实现接口类中的方法
public void HappyMarry() {
before();
this.target.HappyMarry();
after();
}
private void before(){
System.out.println("结婚之前,布置现场");
}
private void after(){
System.out.println("结婚之后,收尾款");
}
}