全局数据 与 singleton 类的选择

2024-05-28 13:12
文章标签 数据 全局 选择 singleton

本文主要是介绍全局数据 与 singleton 类的选择,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1,singleton 相对于全局数据的优势

使用 Singleton 类相对于全局数据具有以下好处:

1.1. 延迟初始化:Singleton 类可以实现延迟初始化,即在需要时才创建实例,而全局数据在程序启动时就会被初始化。这可以节省资源并提高性能。

1.2. 控制访问:Singleton 类可以提供更好的访问控制,通过提供公共静态方法来访问实例,可以限制对实例的访问方式,避免直接访问全局数据。

1.3. 线程安全:Singleton 类可以实现线程安全的实例化,通过加锁或其他线程安全机制来保证在多线程环境下只创建一个实例,而全局数据可能需要额外的同步机制来保证线程安全。

1.4. 更好的封装:Singleton 类提供了更好的封装性,可以隐藏实例化细节并提供更清晰的接口,而全局数据可能会暴露在整个程序中,导致耦合性增加。

1.5. 易于扩展:Singleton 类可以更容易地扩展和维护,可以在类中添加新的功能和行为,而全局数据可能会导致代码膨胀和难以维护。

总的来说,使用 Singleton 类相对于全局数据可以提供更好的封装、控制访问、线程安全性和延迟初始化等优势,使得代码更加健壮、可维护和可扩展。

2,全局数据相对于singleton的优势

使用全局数据相对于 Singleton 类具有以下一些优势:

2.1. 简单性:全局数据的实现通常比 Singleton 类更简单直接,不需要额外的设计模式和复杂的实现。

2.2. 易于访问:全局数据可以在任何地方直接访问,不需要通过特定的接口或方法来获取实例。

2.3. 更快速的访问:全局数据的访问速度可能会更快,因为不需要额外的方法调用或实例化过程。

2.4. 适用性:在某些情况下,全局数据可能更适合特定的应用场景,例如需要在整个程序中共享的配置信息或状态。

2.5. 少量数据:对于少量数据或简单的应用,全局数据可能是更简单和有效的选择,避免引入不必要的复杂性。

3.结论

尽管全局数据具有一些优势,但在大多数情况下,推荐使用 Singleton 类来管理全局状态和数据,因为 Singleton 类提供了更好的封装、控制访问、线程安全性和延迟初始化等优势,使得代码更加健壮、可维护和可扩展。选择使用全局数据还是 Singleton 类取决于具体的需求和设计考虑。

4,singleton C++  DCL 示例

4.1 示例一

单文件示例

hello_dcl_sing.cpp

#include <iostream>
#include <mutex> 
class Singleton {
private:Singleton() {}                             // 私有构造函数static Singleton* instance;                // 单例对象指针static bool inited;                        // 初始化标志static std::mutex mtx;                    // 用于线程同步的互斥锁//
public:// 获取单例对象的方法static Singleton* getInstance() {if (!inited) {                         // 第一次检查,无需同步std::lock_guard<std::mutex> lock(mtx); // 同步块if (!inited) {                     // 第二次检查,确保线程安全instance = new Singleton();    // 安全创建单例对象inited = true;                 // 标记已初始化}}return instance;                       // 返回单例对象}// 其他成员函数和方法...
};Singleton* Singleton::instance = nullptr;      // 静态成员初始化
bool Singleton::inited = false;               // 初始化标志默认为false
std::mutex Singleton::mtx;                    // 用于线程同步的互斥锁int main() {Singleton* s1 = Singleton::getInstance();Singleton* s2 = Singleton::getInstance();if (s1 == s2) {std::cout << "Singletons are the same instance." << std::endl;}return 0;
}

编译运行:

        g++  hello_dcl_sing.cpp

        ./a.out

效果图:

4.2 示例二

双文件示例

源码:

singleton.h

// singleton.h
#ifndef SINGLETON_H
#define SINGLETON_H#include <iostream>
#include <mutex>using namespace std;class Singleton
{
public: 
static Singleton* GetInstance();
void print_info();
private: 
Singleton(int a, int b, int c) {major = a; minor = b; patch = c;} // construction, private
private: static Singleton *m_pSingleton; // pointer points self single instancestatic mutex m_mutex; // lock for thread-safeint major;int minor;int patch;
};#endif // SINGLETON_H

singleton.cpp

// singleton.cpp
#include "singleton.h"Singleton *Singleton::m_pSingleton = NULL;
mutex Singleton::m_mutex;Singleton *Singleton::GetInstance()
{if (m_pSingleton == NULL) { std::lock_guard<std::mutex> lock(m_mutex); // self-unlocking if (m_pSingleton == NULL) { m_pSingleton = new Singleton(1, 2, 3); } } return m_pSingleton;
}void Singleton::print_info()
{printf(" major = %d\n minor = %d\n patch = %d\n", major, minor, patch);
}

app 源码

ex.cpp

#include "singleton.h"int main()
{Singleton::GetInstance()->print_info();return 0;
}

Makefile

all: ex%.o: %.cppg++ $< -c -o $@ex: ex.o singleton.og++ $^ -o $@
.PHONY: clean
clean:-rm -rf ex.o ex singleton.o

编译运行:

这篇关于全局数据 与 singleton 类的选择的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010659

相关文章

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名