zoukankan      html  css  js  c++  java
  • 设计模式课程 设计模式精讲 24-2 中介者模式coding

    1    代码演练

    1.1  代码演练1

    1    代码演练

    1.1  代码演练1

    需求:

    李大X的牛回头 课程qq讨论群,每个人发出信息后,其他人都可看见

    注意:(个人开发中没有注意到的地方)

    a  关于message的处理(如敏感信息的校验等),都可以放到中介者中,不需要封装的user中。

    b  聊天室和qq群这种通常用中介者处理(这种应用较多),关系比较复杂也可以。

    c  类之间把自己传出去,见用户类;

    uml类图:

     

    测试类:

    package com.geely.design.pattern.behavioral.mediator;
    
    /**
     * Created by geely
     */
    public class Test {
        public static void main(String[] args) {
            User geely = new User("Geely");
            User tom= new User("Tom");
    
            geely.sendMessage(" Hey! Tom! Let's learn Design Pattern");
            tom.sendMessage("OK! Geely");
        }
    
    
    }

    qq群消息处理类:

    package com.geely.design.pattern.behavioral.mediator;
    
    import java.util.Date;
    
    /**
     * Created by geely
     */
    public class StudyGroup {
    
    /**
    * 核心方法,将用户的发的消息,通过中介者发出来
    */
    public static void showMessage(User user, String message){ System.out.println(new Date().toString() + " [" + user.getName() + "] : " + message); } }

    用户类:

    package com.geely.design.pattern.behavioral.mediator;
    
    /**
     * Created by geely
     */
    public class User {
        private String name;
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public User(String name) {
            this.name = name;
        }
    
    /**
    * 把自己传过去
    */
    public void sendMessage(String message) { StudyGroup.showMessage(this, message); } }

    打印日志:

    Tue Mar 03 05:51:45 CST 2020 [Geely] :  Hey! Tom! Let's learn Design Pattern
    Tue Mar 03 05:51:45 CST 2020 [Tom] : OK! Geely
    
    Process finished with exit code 0

     

  • 相关阅读:
    Rancher2.x部署K8s
    windows 安装 rabbitmq
    Mysql优化
    Docker部署Nginx应用(2)
    Docker入门笔记(1)
    kafka的安装及基本使用
    Dubbo的Api+Provider+Customer示例(IDEA+Maven+Springboot+dubbo)
    zookeeper 数据节点的增删改查
    zookeeper伪分布集群配置
    密集重建
  • 原文地址:https://www.cnblogs.com/1446358788-qq/p/12400078.html
Copyright © 2011-2022 走看看