设计模式学习篇(一)

直接上代码:

 internal class Program
    {
        private static void Main(string[] args)
        {
            //简单工厂模式
            if (false)
            {
                Operate op = SimpleFactory.CreateOperate("+");
                op.NumberA = 20;
                op.NumberB = 30;
                var result = op.GetResult();
                Console.WriteLine(result);
            }
            //策略模式
            if (false)
            {
                StrategyPattern sp = new StrategyPattern("-");
                var result = sp.GetResult(30, 20);
                Console.WriteLine(result);
            }
            //装饰模式
            if (false)
            {
                OuStyle os = new OuStyle();
                os.AddStyle(new PingFang());
                os.Show();  //  欧式风格  这是平房

                ChineseStyle cs = new ChineseStyle();
                cs.AddStyle(os);  //用欧式风格装饰中国风
                cs.Show();// 中国分隔 欧式风格  这是平房

            }

            if (false)
            {
                IGiveGifts sender = new Persuit();
                Agent agent = new Agent(sender);
                agent.GiveDolls();

            }
            if (true)
            {
                IFactory factory = new AddOperateFactory();
                Operate op= factory.CreateOperate();
                op.NumberA = 20;
                op.NumberB = 30;
                Console.WriteLine(op.GetResult());
            }

            Console.ReadKey();
        }
    }

    #region 1、简单工厂模式

    public  abstract class Operate
    {
        public int NumberA { get; set; }
        public int NumberB { get; set; }

        public virtual int GetResult()
        {
            return 0;
        }
    }

    internal class AddOperate : Operate
    {
        public override int GetResult()
        {
            return this.NumberA + this.NumberB;
        }
    }

    internal class SubOperate : Operate
    {
        public override int GetResult()
        {
            return this.NumberA - this.NumberB;
        }
    }

    /// <summary>
    /// 1、简单工厂模式
    /// </summary>
    internal class SimpleFactory
    {
        public static Operate CreateOperate(string flag)
        {
            switch (flag)
            {
                case "+":
                    return new AddOperate();
                    break;
                case "-":
                    return new SubOperate();
                    break;
                default:
                    return null;
            }
        }
    }

    #endregion

    #region 2、策略模式

    /// <summary>
    /// 在简单工厂模式的基础上,在工厂(类)中,对对象方法进行了再封装 而不是返回对象
    /// </summary>
    internal class StrategyPattern
    {
        private Operate op = null;

        public StrategyPattern(string flag)
        {
            switch (flag)
            {
                case"+":
                    op = new AddOperate();
                    break;

                case"-":
                    op = new SubOperate();
                    break;
                default:
                    op = null;
                    break;
            }
        }

        public int GetResult(int a,int b)
        {
            op.NumberA = a;
            op.NumberB = b;
            return op.GetResult();
        }
    }

    #endregion

    #region 3、装饰模式

    /// <summary>
    /// 抽象接口
    /// </summary>
    internal abstract class House
    {
        public abstract void Show();
    }

    internal class PingFang : House
    {
        public override void Show()
        {
            Console.WriteLine("这是平房");
        }
    }

    internal class LouFang : House
    {
        public override void Show()
        {
            Console.WriteLine("这是楼房");
        }
    }

    /// <summary>
    /// 装饰模式:在当前类中定义继承的类成员,再加个初始该成员的方法,用实现继承类的其它类对象来武装装饰自己
    /// </summary>
    internal class OuStyle:House
    {
        /// <summary>
        /// 将定义用来装饰的对象方法的接口 定义在当前(需要装饰的)类中
        /// </summary>
        private House home = null;

        public override void Show()
        {
            if (null != this.home)
            {
                home.Show();
            }
            Console.WriteLine("欧式风格");

        }

        /// <summary>
        /// 动态添加特定的实现了接口House的类,以便给本类来调用其方法来装饰(武装)自己,
        /// </summary>
        /// <param name="h"></param>
        public void AddStyle(House h)
        {
            this.home = h;
        }

    }

    internal class ChineseStyle : House
    {
        private House h = null;

        public override void Show()
        {
            if (null!=h)
            {
                h.Show();
            }
            Console.WriteLine("这是中国风");

        }

        public void AddStyle(House house)
        {
            this.h = house;
        }

    }

    #endregion

    #region 4、代理模式

    public interface IGiveGifts
    {
        void GiveDolls();
        void GiveFlowers();
    }

    public class Persuit : IGiveGifts
    {

        public void GiveDolls()
        {
            Console.WriteLine("送芭比娃娃");
        }

        public void GiveFlowers()
        {
            Console.WriteLine("送花");
        }
    }

    /// <summary>
    /// 什么是代理模式:本来有一个类A可以直接执行自己的方法就可以实现一个功能,现在先将这个类A作为一个属性传递给一个代理类,代理类在通过自己的方法调用A对象的方法,同时可以添加一些新的功能
    /// </summary>
    public class Agent : IGiveGifts
    {
        private IGiveGifts sender;

        public Agent(IGiveGifts ig)
        {
            this.sender = ig;
        }

        public void GiveDolls()
        {
            sender.GiveDolls();
            Console.WriteLine("我是**代理 送芭比娃娃");
        }

        public void GiveFlowers()
        {
            sender.GiveFlowers();
            Console.WriteLine("我是**代理 送花");

        }

    }

    #endregion

    #region 5、工厂方法模式

    /// <summary>
    /// 工厂模式存在类与switch语句的高耦合,增加新的类 需要去增加case分支,违背了开放-封闭原则 工厂方法模式可以解决这个问题。
    /// </summary>
    public interface IFactory
    {
        Operate CreateOperate();
    }

    public class AddOperateFactory:IFactory
    {
        public Operate CreateOperate()
        {
            return new AddOperate();
        }
    }

    public class SubOperateFactory : IFactory
    {

        public Operate CreateOperate()
        {
            return new SubOperate();
        }
    }

    #endregion

时间: 2024-10-21 18:47:04

设计模式学习篇(一)的相关文章

设计模式学习笔记(目录篇)

设计模式学习笔记(目录篇) 为了方便查看,特此将设计模式学习笔记系列单独做一个目录. 1   设计模式学习笔记(一:命令模式) 2   设计模式学习笔记(二:观察者模式) 3   设计模式学习笔记(三:装饰模式) 4   设计模式学习笔记(四:策略模式) 5   设计模式学习笔记(五:适配器模式) 6   设计模式学习笔记(六:责任链模式) 7   设计模式学习笔记(七:外观模式) 8   设计模式学习笔记(八:迭代器模式) 9   设计模式学习笔记(九:中介者模式) 10  设计模式学习笔记(

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过

java/android 设计模式学习笔记(一)---单例模式

前段时间公司一些同事在讨论单例模式(我是最渣的一个,都插不上嘴 T__T ),这个模式使用的频率很高,也可能是很多人最熟悉的设计模式,当然单例模式也算是最简单的设计模式之一吧,简单归简单,但是在实际使用的时候也会有一些坑. PS:对技术感兴趣的同鞋加群544645972一起交流 设计模式总目录 java/android 设计模式学习笔记目录 特点 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的使用很广泛,比如:线程池(threadpool).缓存(cache).对

java/android 设计模式学习笔记(7)---装饰者模式

这篇将会介绍装饰者模式(Decorator Pattern),装饰者模式也称为包装模式(Wrapper Pattern),结构型模式之一,其使用一种对客户端透明的方式来动态的扩展对象的功能,同时它也是继承关系的一种替代方案之一,但比继承更加灵活.在现实生活中也可以看到很多装饰者模式的例子,或者可以大胆的说装饰者模式无处不在,就拿一件东西来说,可以给它披上无数层不一样的外壳,但是这件东西还是这件东西,外壳不过是用来扩展这个东西的功能而已,这就是装饰者模式,装饰者的这个角色也许各不相同但是被装饰的对

java/android 设计模式学习笔记(13)---享元模式

这篇我们来介绍一下享元模式(Flyweight Pattern),Flyweight 代表轻量级的意思,享元模式是对象池的一种实现.享元模式用来尽可能减少内存使用量,它适合用于可能存在大量重复对象的场景,缓存可共享的对象,来达到对象共享和避免创建过多对象的效果,这样一来就可以提升性能,避免内存移除和频繁 GC 等. 享元模式的一个经典使用案例是文本系统中图形显示所用的数据结构,一个文本系统能够显示的字符种类就是那么几十上百个,那么就定义这么些基础字符对象,存储每个字符的显示外形和其他的格式化数据

OC学习篇之---单例模式

在之前的一片文章中介绍了对象的拷贝相关知识:http://blog.csdn.net/jiangwei0910410003/article/details/41926531,今天我们来看一下OC中的单例模式,单例模式在设计模式中用的可能是最多的一种了,而且也是最简单的一种 实现单例模式有三个条件 1.类的构造方法是私有的 2.类提供一个类方法用于产生对象 3.类中有一个私有的自己对象 针对于这三个条件,OC中都是可以做到的 1.类的构造方法是私有的 我们只需要重写allocWithZone方法,

设计模式学习第一讲

李建忠 设计模式 学习笔记(链接:http://pan.baidu.com/s/1hqiVfa0 密码:7kfk) 1.面向对象思想是面向接口编程 2.优先使用类继承 3.只有非常强的 is a 才使用类继承 4.使用[重构]得到模式,设计模式不能先入为主 5.源代码就是设计——一篇论文 设计原则: 1).单一职责原则(SRP): 一个类应该仅有一个引起它变化的原因 2).开放封闭原则(OCP) 类模块应该是可扩展的,但是不可修改(对扩展开放,对更改封闭) 3).Liskov替换原则(LSP)

java/android 设计模式学习笔记(12)---组合模式

这篇我们来介绍一下组合模式(Composite Pattern),它也称为部分整体模式(Part-Whole Pattern),结构型模式之一.组合模式比较简单,它将一组相似的对象看作一个对象处理,并根据一个树状结构来组合对象,然后提供一个统一的方法去访问相应的对象,以此忽略掉对象与对象集合之间的差别.这个最典型的例子就是数据结构中的树了,如果一个节点有子节点,那么它就是枝干节点,如果没有子节点,那么它就是叶子节点,那么怎么把枝干节点和叶子节点统一当作一种对象处理呢?这就需要用到组合模式了. 转