C++中实现Singleton的正确方法
作者:网络转载 发布时间:[ 2013/3/8 10:48:54 ] 推荐标签:
尽管这是一个精心设计的错误,但在大型项目中出现这类错误的可能性却并不小。因为在现实项目中,singleton1_t和singleton2_t两个类的实现很可能是在不同的源文件中,这势必造成两个类实例的初始化顺序会因链接顺序不同而不同,《揭示C++中全局类变量的构造与析构顺序》一文介绍了这是为什么。
在本例中,如果将第39行和第40行的代码进行对调不会出现这种奇怪的现象,但这不是解决问题的方法。更好的方法需要更改singleton的实现方法,图3示例了一种新的实现方法。
main.c
00001: #include <iostream>
00002:
00003: using namespace std;
00004:
00005: class singleton1_t
00006: {
00007: public:
00008: static singleton1_t *instance ()
00009: {
00010: if (0 == p_instance_) {
00011: p_instance_ = new singleton1_t;
00012: }
00013: return p_instance_;
00014: }
00015:
00016: void count_increase () {count_ ++;}
00017: int count () const {return count_;}
00018:
00019: private:
00020: singleton1_t (): count_ (0) {}
00021: ~singleton1_t () {}
00022:
00023: static singleton1_t *p_instance_;
00024: int count_;
00025: };
00026:
00027: class singleton2_t
00028: {
00029: public:
00030: static singleton2_t *instance ()
00031: {
00032: if (0 == p_instance_) {
00033: p_instance_ = new singleton2_t;
00034: }
00035: return p_instance_;
00036: }
00037:
00038: private:
00039: singleton2_t () {singleton1_t::instance ()->count_increase ();}
00040: ~singleton2_t () {}
00041:
00042: static singleton2_t *p_instance_;
00043: };
00044:
00045: singleton2_t *singleton2_t::p_instance_ = 0;
00046: singleton1_t *singleton1_t::p_instance_ = 0;
00047:
00048: int main ()
00049: {
00050: singleton2_t::instance ();
00051: cout << "count = " << singleton1_t::instance ()->count () << endl;
00052: return 0;
00053: }
新实现大的变化,在于将以前的类静态变量从类实例变成了类指针,并在instance()函数中需要时通过new操作符创建类实例。指针在C++中仍是当作一种原始数据类型处理的,其初始化与类实例的初始化不同,不需调用类构造函数。在这一实现中,两个类的静态变量p_instance_的初始化都是在程序的.bss段初始化时一次性完成的。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11