博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解析C#开发过程常见的编程模式
阅读量:5892 次
发布时间:2019-06-19

本文共 1493 字,大约阅读时间需要 4 分钟。

单例模式:

在多线程的程序开发过程中经常会遇到单例模式[单件模式],它的特点是不是根据客户程序的调用而生成新的实例,而是控制某个类型的实例数量只有一个。也就是说,单例模式就是保证在整个应用程序的生命周期中,在任何时刻,被指定的类只有一个实例,并为客户程序提供一个获取该实例的全局访问点。

接下来看一个经典的单例模式:

public class SingleInstance{    private static SingleInstance _instance=null;        private SingleInstance()    {    }        public SingleInstance GetInstance()    {        if(null==_instance)        {            _instance=new SingleInstance();        }                return _instance;    }}
View Code

但是以上经典的单例模式并没有考虑到多线程并发的问题,以下这段代码是对上述代码的完善以解决多线程并发问题,多线程下的单例模式[Lazy 模式]:

public class SingleInstance{    private static SingleInstance _instance=null;        private static Object _lock=new Object();        private SingelInstance()    {    }        public SingleInstance GetInstance()    {        if(null==_instance)        {            lock(_lock)            {                if(null==_instance)                {                    _instance=new SingleInstance();                }            }        }                return _instance;    }}
View Code

还有另外一种饿汉模式,程序代码如下:

public class SingleInstance{    private static readonly SingleInstance _instance=new SingleInstance();        private SingleInstance()    {    }        public SingleInstance GetInstance()    {        return _instance;    }}
View Code

这种模式使用的readonly关键可以跟static一起使用,用于指定该常量是类别级的,它的初始化交由静态构造函数实现,并可以在运行时编译。在这种模式下,无需自己解决线程安全性问题,CLR会给我们解决。由此可以看到这个类被加载时,会自动实例化这个类,而不用在第一次调用GetInstance()后才实例化出唯一的单例对象。

待续。。。

转载于:https://www.cnblogs.com/chengbing2011/p/4267873.html

你可能感兴趣的文章
视频直播点播nginx-rtmp开发手册中文版
查看>>
PHP队列的实现
查看>>
单点登录加验证码例子
查看>>
[T-SQL]从变量与数据类型说起
查看>>
occActiveX - ActiveX with OpenCASCADE
查看>>
BeanUtils\DBUtils
查看>>
Android利用文本分割拼接开发一个花藤文字生成
查看>>
[转]理解Linux文件系统之inode
查看>>
python模块--os模块
查看>>
linux下单节点oracle数据库间ogg搭建
查看>>
swift三方库
查看>>
POJ NOI0105-42 画矩形
查看>>
Java 数组在内存中的结构
查看>>
《关爱码农成长计划》第一期报告
查看>>
学习进度表 04
查看>>
谈谈javascript中的prototype与继承
查看>>
时序约束优先级_Vivado工程经验与各种时序约束技巧分享
查看>>
minio 并发数_MinIO 参数解析与限制
查看>>
mysql 应用程序是哪个文件夹_Mysql 数据库文件存储在哪个目录?
查看>>
mysql半同步和无损复制_MySQL半同步复制你可能没有注意的点
查看>>