新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
饿汉式
创新互联建站拥有网站维护技术和项目管理团队,建立的售前、实施和售后服务体系,为客户提供定制化的网站设计、成都做网站、网站维护、成都棕树电信机房解决方案。为客户网站安全和日常运维提供整体管家式外包优质服务。我们的网站维护服务覆盖集团企业、上市公司、外企网站、成都做商城网站、政府网站等各类型客户群体,为全球数千家企业提供全方位网站维护、服务器维护解决方案。
#includeusing namespace std; class A{ public: static A& getInstance(void){ return s_instance; } private: A(int data=0):m_data(data){} A(A const& that); int m_data; static A s_instance; }; A A::s_instance(1234); int main(void){ A& a1 = A::getInstance(); A& a2 = A::getInstance(); cout << &a1 << ',' << &a2 << endl; return 0; }
这个是以静态成员作为单例的。
因为是单例,所以禁止创建其他A类对象,A a调用构造函数创建对象,所以将A类的构造函数放在
private里,A a = A::getInstance()调用拷贝构造函数创建对象,所以将拷贝构造函数放在private里
面,同时接口函数static A& getInstance(void),是静态的,如果是非静态的,那么怎么调用getInstance
函数呢,所以必须是静态的.
注意:静态成员对象s_instance是可以调用私有的构造函数的(我也不知道为什么).
2.懒汉式
#includeusing namespace std; class A{ public: static A& getInstance(void){ if(!s_instance){ s_instance = new A(1234); } return *s_instance; } void release(void){ if(s_counter && --s_counter==0){ delete this; s_instance = NULL; } } private: ~A(void){} A(int data = 0):m_data(data){} A(A const& that); int m_data; static int s_counter; static A* s_instance; }; int A::s_counter = 0; A* A::s_instance = NULL; int main(void){ A& a1 = A::getInstance(); A& a2 = A::getInstance(); cout << &a1 << ',' << &a1 << endl; a1.release(); a2.release(); return 0; }
这里是以静态成员指针作为单例,也没什么好说的了.
注意:静态成员指针s_instance,在new A(1234)时调用构造函数,但是在delete this时,是不会调用析够函数的,不管是公有的析构函数还是私有的析构函数(为什么不能调用析构函数我也不知道)