东莞阳光网官方网站,跨平台 移动网站开发,宝塔建站详细教程,全程电子化服务平台单例模式 引言正文1. 饿汉式单例2. 带双重检查锁定机制的懒汉式单例3. IoDH技术的单例 结论优点饿汉式单例带双重检查锁定机制的懒汉式单例IoDH技术的单例 缺点饿汉式单例带双重检查锁定机制的懒汉式单例IoDH技术的单例 引言
在软件开发中#xff0c;单例模式是一种很常用的设… 单例模式 引言正文1. 饿汉式单例2. 带双重检查锁定机制的懒汉式单例3. IoDH技术的单例 结论优点饿汉式单例带双重检查锁定机制的懒汉式单例IoDH技术的单例 缺点饿汉式单例带双重检查锁定机制的懒汉式单例IoDH技术的单例 引言
在软件开发中单例模式是一种很常用的设计模式。它确保类只有一个实例并提供全局访问点以便在整个应用程序中共享这个实例。比如我们的日志系统、数据库连接池、线程池等等都会用到。 本文将讨论三种常见的单例模式实现方式分别是饿汉式单例、带双重检查锁定机制的懒汉式单例以及IoDH技术的单例。通过这三种实现方式可以更好地理解单例模式的概念和使用。
正文
1. 饿汉式单例
饿汉式单例是指在程序初始化阶段就创建出唯一的实例。它的特点是类在加载时就创建对象所以不存在线程安全问题。以下是一个使用C实现的饿汉式单例的示例代码
class Singleton {
private:static Singleton* instance;// 私有构造函数防止外部实例化Singleton() {}public:static Singleton* getInstance() {return instance;}
};// 在类外初始化静态成员变量
Singleton* Singleton::instance new Singleton();2. 带双重检查锁定机制的懒汉式单例
懒汉式单例是指在需要使用实例时才进行创建。它的特点是在多线程环境下需要进行双重检查锁定以确保只有一个实例被创建。以下是一个使用C实现的带双重检查锁定机制的懒汉式单例的示例代码
#include mutexclass Singleton {
private:static Singleton* instance;static std::mutex mtx;// 私有构造函数防止外部实例化Singleton() {}public:static Singleton* getInstance() {if (instance nullptr) {std::lock_guardstd::mutex lock(mtx);if (instance nullptr) {instance new Singleton();}}return instance;}
};Singleton* Singleton::instance nullptr;
std::mutex Singleton::mtx;3. IoDH技术的单例
IoDHInitialization-on-Demand Holder技术是一种结合了饿汉式和懒汉式单例的实现方式。它是利用了静态局部变量的特性在需要时才创建实例并且在多线程环境下也能确保线程安全。以下是一个使用C实现的IoDH技术的单例的示例代码
class Singleton {
private:Singleton() {}public:static Singleton* getInstance() {static Singleton instance;return instance;}
};结论
优点
饿汉式单例
天然支持多线程。
带双重检查锁定机制的懒汉式单例
延迟创建系统初始化时负荷小。
IoDH技术的单例
支持多线程同时支持延迟创建。
缺点
饿汉式单例
①初始化负荷大。②资源浪费可能场景为系统在启动很长时间内不适用该单例的实例对象或者甚至在声明周期内不适用。③对于c这种没有垃圾回收机制的语言还好对于golang或者java这种有垃圾回收的语言可能会存在单例一开始被创建好了中途因为长时间不用又被回收了用的时候又会再次创建导致反复的开销。
带双重检查锁定机制的懒汉式单例
每次获取单例对象都需要加锁影响系统性能。比如系统系统打日志每次都需要去获取获取锁多线程之间就会有严重的竞争导致性能下降。
IoDH技术的单例
无缺点暂时是完美的。