Java多线程0-静态代理模式

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("结婚之后,收尾款");
    }
}
上一篇:Linux安装jdk和配置环境变量


下一篇:rabbitmq学习记录