• 桥接模式二(Bridge)


         昨天写到了桥接模式的代码实现,今天我们就继续来讲完桥接模式。
          有认真看的会发现,昨天的代码实现只是两个维度的变化;哪么有人可能就会问了哪如果我要加多一个维度呢?我要具体到企业的哪个部门,哪我们应该怎么加呢?下面我就给大家看看代码是怎么实现的。
          要想实现加入部门这个维度只要添加以下代码:
          

    abstract class department
    {
        workyya Wyy;
        public workyya wyy
        {
            get
            {
                return Wyy;
            }
            set
            {
                Wyy = value;
            }
        }
     
        public abstract void departmentwyy();
    }
     
    class information : department
    {
        public override void departmentwyy()
        {
            Console.WriteLine("信息部");
            wyy.work();
        }
    }

    客户端调用:

    static void Main(string[] args)
     {
          
     
         workyya yya = new workcar();
         yya.Full = new xiaomin();
     
         department dep = new information();
         dep.wyy = yya;
         dep.departmentwyy();
         Console.Read();
     }

      好了,看到这两段代码大家应该知道桥接模式应该怎么去实现了。
           到这里我们回过头来考虑传统的做法,我们只使用类的继承这一方式来实现以上的例子。你会发现如果用传统的作法会产生很多子类,扩展性差,可维护差;而且耦合度很高(不了解继承的可以自己去找找资料,搞懂类的继承是怎么一回事,对你会有很大的帮忙)。
           而使用桥接模式的话,从结构类中我们就可以看出桥接的耦合度低,每个对象之间各不影响,都有自己独立的变化。
           至于桥接模式的适应用性,优缺点有兴趣的可以自行了解(毕竟每个人的理解都有所不同,只有自己用心去理解出来的才是最好的、印象也才最ips)

    语言组织不太好,请多多包含。。。

    另:此文章本人已在ibc编程社区写过要想看原文请到http://www.ibcibc.com/forum.php?mod=viewthread&tid=4596

    原文里有源代码

  • 相关阅读:
    【个人】排序练习
    lintcode:二叉树的层次遍历
    lintcode:子集 & 带重复元素的子集
    lintcode:全排列&带重复元素的排列
    5.2哈夫曼树——哈夫曼树与哈夫曼编码
    5.1 堆 —— 堆的定义与操作
    04-树7 二叉搜索树的操作集
    04-树6 Complete Binary Search Tree
    04-树5 Root of AVL Tree
    04-树4 是否同一棵二叉搜索树
  • 原文地址:https://www.cnblogs.com/ljhboke/p/6370689.html
Copyright © 2020-2023  润新知