首页 > 编程语言 >.NET(C#) 设计模式

.NET(C#) 设计模式

时间:2023-07-25 13:34:53浏览次数:40  
标签:Singleton Console C# void class new NET 设计模式 public

.NET(C#) 设计模式

简介

设计模式(Design pattern)是代码设计经验的总结。设计模式主要分三个类型:创建型、结构型和行为型。创建型是对象实例化的模式,创建型模式用于解耦对象的实例化过程,主要用于创建对象。结构型是把类或对象结合在一起形成一个更大的结构,主要用于优化不同类、对象、接口之间的结构关系。行为型是类和对象如何交互,及划分责任和算法。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。

创建型

单例模式(Singleton)

单例模式,属于创建类型的一种常用的软件设计模式。通过单例模式的方法创建的类在当前进程中只有一个实例。

1)普通单例模式

using System;
namespace SingletonPattern
{
    /// 
    /// 单例模式(非线程安全)
    /// 
    public class Singleton
    {
        private static Singleton singleton;
        private Singleton() { }
        /// 
        /// 获取实例-线程非安全模式
        /// 
        /// 
        public static Singleton GetSingleton()
        {
            if (singleton == null)
                singleton = new Singleton();
            return singleton;
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            var obj = Singleton.GetSingleton();
            Console.ReadKey();
        }
    }
}

2)懒汉式单例模式

using System;
namespace ConsoleApplication
{
    /// 
    /// 单例类:一个构造对象很耗时耗资源类型
    /// 
    /// 懒汉式单例模式
    /// 
    public class Singleton// //泛型类型里面的静态字段,是随着不同的类型参数唯一的  泛型单例是不可能的
    {
        /// 
        /// 构造函数耗时耗资源
        /// 
        private Singleton()
        {
        }
        /// 
        /// 全局唯一静态  重用这个变量
        /// 
        private static volatile Singleton _Singleton = null;
        //volatile是C#中用于控制同步的关键字,其意义是针对程序中一些敏感数据,
        //不允许多线程同时访问,保证数据在任何访问时刻,最多有一个线程访问,以保证数据的完整性,volatile是修饰变量的修饰符。
        private static object Singleton_Lock = new object();
        /// 
        /// 2 公开的静态方法提供对象实例
        /// 
        /// 
        public static Singleton CreateInstance()
        {
            if (_Singleton == null)
            {
                lock (Singleton_Lock)//保证只有一个线程进去判断+初始化
                {
                    if (_Singleton == null)
                    {
                        _Singleton = new Singleton();
                    }
                }
            }
            return _Singleton;
        }//懒汉式  调用了方法才去构造
    }
    class Program
    {
        static void Main(string[] args)
        {
            var obj = Singleton.CreateInstance();
            Console.ReadKey();
        }
    }
}

3)饿汉式单例模式

using System;
namespace ConsoleApplication
{
    /// 
    /// 单例类:一个构造对象很耗时耗资源类型
    /// 饿汉式
    /// 
    public class Singleton
    {
        /// 
        /// 构造函数耗时耗资源
        /// 
        private Singleton()
        {
        }
        /// 
        /// 静态字段:在第一次使用这个类之前,由CLR保证,初始化且只初始化一次
        /// 这个比今天构造函数还早
        /// 
        private static Singleton _Singleton = new Singleton();
        public static Singleton CreateInstance()
        {
            return _Singleton;
        }//饿汉式  只要使用类就会被构造
    }
    class Program
    {
        static void Main(string[] args)
        {
            var obj = Singleton.CreateInstance();
            Console.ReadKey();
        }
    }

}

或者

using System;
namespace ConsoleApplication
{
    /// 
    /// 单例类:一个构造对象很耗时耗资源类型
    /// 
    /// 饿汉式
    /// 
    public class Singleton
    {
        /// 
        /// 1 构造函数耗时耗资源
        /// 
        private Singleton()
        {
        }
        /// 
        /// 静态构造函数:由CLR保证,程序第一次使用这个类型前被调用,且只调用一次
        /// 
        /// 
        static Singleton()
        {
            _Singleton = new Singleton();
        }
        private static Singleton _Singleton = null;
        public static Singleton CreateInstance()
        {
            return _Singleton;
        }//饿汉式  只要使用类就会被构造
    }
    class Program
    {
        static void Main(string[] args)
        {
           var obj= Singleton.CreateInstance();
            Console.ReadKey();
        }
    }
}

工厂方法模式(Factory Method)

工厂方法模式(Factory Method)的出现解决简单工厂中的难以拓展的问题,解决了其一旦添加新的产品,则需要修改简单工厂方法,进而造成简单工厂的实现逻辑过于复杂。工厂方法模式通过面向对象编程中的多态性来将对象的创建延迟到具体工厂中,把具体产品的创建推迟到子类中,此时工厂类不再负责所有产品的创建,而只是给出具体工厂必须实现的接口,工厂方法模式就可以允许系统不修改工厂类逻辑的情况下来添加新产品,也就克服了简单工厂模式中缺点。工厂方法模式也是属于创建型模式。

using System;
namespace ConsoleApplication
{
    //一般每个接口或类都写在单独的.cs文件中
    //本示例为了执行查看方便才写在一起
    public interface IDatabase
    {
        void Delete();
        void Insert();
    }
    //Sqlserver的增删
    public class Sqlserver : IDatabase
    {
        public void Delete()
        {
            Console.WriteLine("delete data from sqlserver");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to sqlserver");
        }
    }
    //Mysql的增删
    public class Mysql : IDatabase
    {
        public void Delete()
        {
            Console.WriteLine("delete data from Mysql");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to Mysql");
        }
    }
    public interface ICreator
    {
        IDatabase CreateDatabase();
    }
    public class MysqlFactory:ICreator
    {
        /// <summary>
        /// 负责创建Mysql
        /// </summary>
        /// <returns></returns>
        public IDatabase CreateDatabase()
        {
            return new Mysql();
        }
    }
    public class SqlserverFactory:ICreator
    {
        /// <summary>
        /// 负责创建Sqlserver
        /// </summary>
        /// <returns></returns>
        public IDatabase CreateDatabase()
        {
            return new Sqlserver();
        }
    }
    /*public static class IFactory
    {
        //根据需求创建
        public static Database CreateDatabase(string dbType)
        {
            Database db = null;
            switch (dbType)
            {
                case "Sqlserver":
                    db = new Sqlserver();
                    break;
                case "Mysql":
                    db = new Mysql();
                    break;
                default:
                    break;
            }
            return db;
        }
    }*/
    class Program
    {
        static void Main(string[] args)
        {
            IDatabase db1 = new SqlserverFactory().CreateDatabase();
            db1.Delete();
            db1.Insert();
            IDatabase db2 = new MysqlFactory().CreateDatabase();
            db2.Delete();
            db2.Insert();
            //添加新数据库直接添加对应的类即可
            Console.ReadKey();
        }
    }
}

抽象工厂模式(Abstract Factory)

抽象工厂模式(Abstract Factory Pattern)是一个超级工厂创建其他工厂。该超级工厂又称为其他工厂的工厂。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。工厂方法模式是为了克服简单工厂模式的缺点而设计出来的,简单工厂模式的工厂类着产品类的增加需要增加额外的代码,而工厂方法模式每个具体工厂类只完成单个实例的创建,它具有很好的可扩展性。但是在现实生活中,一个工厂只创建单个产品比较少,工厂都多元化,一个工厂创建一系列的产品,如果我们要设计这样的系统时,工厂方法模式就不太适用,而使用抽象工厂模式却可以很好地解决。

using System;
namespace ConsoleApplication
{
    //一般每个接口或类都写在单独的.cs文件中
    //本示例为了执行查看方便才写在一起
    public interface IDatabase
    {
        void Delete();
        void Insert();
    }
    public interface IORM
    {
        void Delete();
        void Insert();
    }
    //Sqlserver的增删
    public class Sqlserver : IDatabase
    {
        public void Delete()
        {
            Console.WriteLine("delete data from sqlserver");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to sqlserver");
        }
    }
    //Mysql的增删
    public class Mysql : IDatabase
    {
        public void Delete()
        {
            Console.WriteLine("delete data from Mysql");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to Mysql");
        }
    }
  //Sqlserver的增删
    public class SqlserverORM : IORM
    {
        public void Delete()
        {
            Console.WriteLine("delete data from sqlserver by ORM");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to sqlserver by ORM");
        }
    }
    //Mysql的增删
    public class MysqlORM : IORM
    {
        public void Delete()
        {
            Console.WriteLine("delete data from Mysql by ORM");
        }
        public void Insert()
        {
            Console.WriteLine("insert data to Mysql by ORM");
        }
    }
    public interface ICreator
    {
        IDatabase CreateDatabase();
        IORM CreateORM();
    }
    public class MysqlFactory:ICreator
    {
        /// 
        /// 负责创建Mysql
        /// 
        /// 
        public IDatabase CreateDatabase()
        {
            return new Mysql();
        }
       /// 
        /// 负责创建MysqlORM
        /// 
        /// 
        public IORM CreateORM()
        {
            return new MysqlORM();
        }
    }
    public class SqlserverFactory:ICreator
    {
        /// 
        /// 负责创建Sqlserver
        /// 
        /// 
        public IDatabase CreateDatabase()
        {
            return new Sqlserver();
        }
        /// 
        /// 负责创建SqlserverORM
        /// 
        /// 
        public IORM CreateORM()
        {
            return new SqlserverORM();
        }
    }
    /*public static class IFactory
    {
        //根据需求创建
        public static Database CreateDatabase(string dbType)
        {
            Database db = null;
            switch (dbType)
            {
                case "Sqlserver":
                    db = new Sqlserver();
                    break;
                case "Mysql":
                    db = new Mysql();
                    break;
                default:
                    break;
            }
            return db;
        }
    }*/
    class Program
    {
        static void Main(string[] args)
        {
            IDatabase db1 = new SqlserverFactory().CreateDatabase();
            db1.Delete();
            db1.Insert();
            IDatabase db2 = new MysqlFactory().CreateDatabase();
            db2.Delete();
            db2.Insert();
            IORM db3 = new SqlserverFactory().CreateORM();
            db3.Delete();
            db3.Insert();
            IORM db4 = new MysqlFactory().CreateORM();
            db4.Delete();
            db4.Insert();
            //添加新数据库直接添加对应的类即可
            Console.ReadKey();
        }
    }
}

结构型

适配器模式(Adapter Pattern)

适配器模式(Adapter Pattern)也称包装样式或者包装(wrapper)。将一个类的接口转接成用户所期待的。适配器模式是一种结构型模式,一个适配使得因接口不兼容而不能在一起工作的类工作在一起,做法是将类自己的接口包裹在一个已存在的类中。将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。

1)类适配器模式

using System;
namespace ConsoleApplication
{
    //目标接口
    //现有的
    interface ITarget
    {
        void request();
    }
    //用户所期待的
    class Adaptee
    {
        public void specificRequest()
        {
            Console.WriteLine("适配者中的业务代码被调用!");
        }
    }
    //类适配器类
    class ClassAdapter : Adaptee, ITarget
    {
        public void request()
        {
            specificRequest();
        }
    }
    //客户端代码
    class Program
    {
        public static void Main(String[] args)
        {
            Console.WriteLine("类适配器模式测试:");
            ITarget target = new ClassAdapter();
            target.request();
        }
    }
}

2)对象适配器模式

using System;
namespace ConsoleApplication
{
    //目标接口
    //现有的
    interface ITarget
    {
        void request();
    }
    //用户所期待的
    class Adaptee
    {
        public void specificRequest()
        {
            Console.WriteLine("适配者中的业务代码被调用!");
        }
    }
    //对象适配器类
    class ObjectAdapter : ITarget
    {
         private Adaptee adaptee;
        public ObjectAdapter(Adaptee adaptee)
        {
            this.adaptee = adaptee;
        }
        public void request()
        {
            adaptee.specificRequest();
        }
    }
    //客户端代码
    class Program
    {
        public static void Main(String[] args)
        {
            Console.WriteLine("对象适配器模式测试:");
            Adaptee adaptee = new Adaptee();
            ITarget target = new ObjectAdapter(adaptee);
            target.request();
        }
    }
}

行为型

标签:Singleton,Console,C#,void,class,new,NET,设计模式,public
From: https://www.cnblogs.com/shenghuotaiai/p/17224021.html

相关文章

  • Tesseract开源的OCR工具及python pytesseract安装使用
    一、介绍Tesseract是一款由Google赞助的开源OCR。pytesseract是python包装器,它为可执行文件提供了pythonicAPI。Tesseract已经有30年历史,开始它是惠普实验室的一款专利软件,在2005年后由Google接手并进一步开发和完善。Tesseract支持多种语言文字的检测和识别,包括中文、英......
  • calico报错son: cannot unmarshal string into Go struct field NetConf.mtu of type
     于是describe查看宿主机的配置文件查看日志没有相关日志查看calico的相关配置文件值找到于是想着直接去修改calico的Configmap发现修改不成功便去查询宿主机映射的calico挂载文件把标记部分的string给成int去掉双引号,然后重启calico然后通过ansible分发到每台机器上an......
  • Python的OCR工具pytesseract解决TesseractNotFoundError: tesseract is not installed
    pytesseract是基于Python的OCR工具,底层使用的是Google的Tesseract-OCR引擎,支持识别图片中的文字,支持jpeg,png,gif,bmp,tiff等图片格式。如何安装使用请看我的上一篇。在使用pytesseract打开图片是遇到没有找到文件解决pytesseract.pytesseract.TesseractNotFoundError:te......
  • 揭开 MFCC 的魔力:语音识别的一项关键技术
    现在,在阅读此博客之前,您必须知道MFCC(梅尔频率倒谱系数)广泛用于人工智能中的语音识别。MFCC基本上用于从给定的音频信号中提取特征。我们先来看一下MFCC中涉及的步骤的流程图说明:模数转换:此步骤基本上涉及将模拟信号转换为数字信号。这是因为我们在语音识别中执行的大多数步骤都......
  • Codeforces Round 887 (Div. 2) A-D
    CodeforcesRound887(Div.2)A.Desorting题意:给出一个数组,可以进行任意次以下操作:选择一个i对于数组中的a[1],a[2],...,a[i]全部+1a[i+1]...a[n]全部-1,问最小使得数组变得无序的操作是多少次Solution直接找相邻的两个数的最小的差值即可voidsolve(){ intn;cin>>n......
  • AtCoder Beginner Contest 311
    A-FirstABC#include<bits/stdc++.h>usingnamespacestd;#defineintlonglongint32_tmain(){ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr);intn;strings;cin>>n>>s;set<char>c......
  • linq lambda 两个list求交集:根据每一项模糊匹配(contains) 并且带出where过滤条件里
    直接使用 varresult=list1.Where(str1=>list2.Contains(str))是不行的,这个要求两个list的string值必须有相等的才行例如list1中有apple,那么list2中必须有apple才能匹配,而list2中只有app所以匹配不了 解决办法:List<string>list1=newList<string>{"apple","......
  • Educational Codeforces Round 71 (Rated for Div. 2)
    EducationalCodeforcesRound71(RatedforDiv.2)A-ThereAreTwoTypesOfBurgers思路:价格高的优先取#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong//#defineint__int128typedefpair<int,int>PII;typedefpair<string,int&......
  • JavaScript 中的Promise学习
     代码示例:<scripttype="text/javascript">newPromise(function(resolve,reject){console.log(111);resolve(222);}).then(function(value){console.log(value);......
  • Unicode、ASCII、UTF-8区别与联系
    概念梳理ASCII字符集ASCII:ASCII是美国标准信息交换码的缩写,是一种基于拉丁字母的字符编码标准。ASCII使用7位二进制数(也就是0-127)来表示每个字符,因此它最多可以表示128个不同的字符。ASCII是所有现代字符编码方案的基础。ASCII字符编码其实只使用了7位,取值范围是0......