C++實(shí)現(xiàn)單例模式的方法
更新時間:2021年12月17日 16:37:10 作者:tarespan
這篇文章主要為大家介紹了C++實(shí)現(xiàn)單例模式的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
餓漢模式
類實(shí)例化就會占用內(nèi)存,浪費(fèi)資源,效率高,不存在線程安全問題。
class Singleton{
Singleton() { }
static Singleton* m_instance_ptr;
public:
static Singleton* get_instance() {
return m_instance_ptr;
}
};
Singleton* Singleton::m_instance_ptr = new Singleton();
int main(){
Singleton* instance1 = Singleton::get_instance();
Singleton* instance2 = Singleton::get_instance();
return 0;
}
懶漢模式
延遲加載,節(jié)省資源,效率低,存在線程安全問題。
class Singleton {
Singleton() { }
static Singleton* m_instance_ptr;
public:
static Singleton* get_instance() {
if(m_instance_ptr == nullptr)
m_instance_ptr = new Singleton();
return m_instance_ptr;
}
};
Singleton* Singleton::m_instance_ptr = nullptr;
int main(){
Singleton* instance1 = Singleton::get_instance();
Singleton* instance2 = Singleton::get_instance();
return 0;
}
鎖 + 智能指針
線程安全(鎖)+ 內(nèi)存回收(智能指針)
#include <iostream>
#include <memory>
#include <mutex>
class Singleton {
public:
typedef std::shared_ptr<Singleton> Ptr;
static Ptr get_instance() {
if(m_instance_ptr == nullptr) {
std::lock_guard<std::mutex> lk(m_mutex);
if(m_instance_ptr == nullptr)
m_instance_ptr = std::shared_ptr<Singleton>(new Singleton);
}
return m_instance_ptr;
}
private:
Singleton() {}
static Ptr m_instance_ptr;
static std::mutex m_mutex;
};
Singleton::Ptr Singleton::m_instance_ptr = nullptr;
std::mutex Singleton::m_mutex;
int main(){
Singleton::Ptr instance1 = Singleton::get_instance();
Singleton::Ptr instance2 = Singleton::get_instance();
return 0;
}
局部靜態(tài)變量
class Singleton {
public:
Singleton(const Singleton&)=delete;
static Singleton& get_instance() {
static Singleton instance;
return instance;
}
private:
Singleton() {}
};
int main() {
Singleton& instance1 = Singleton::get_instance();
Singleton& instance2 = Singleton::get_instance();
return 0;
}
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Prim(普里姆)算法求最小生成樹的思想及C語言實(shí)例講解
Prim算法能夠在帶權(quán)的圖中搜索出最小生成樹,這也是各大ACM和面試及考研題目中的熱點(diǎn),下面我們就來詳細(xì)看一下Prim(普里姆)算法求最小生成樹的思想及C語言實(shí)例講解2016-06-06
Matlab實(shí)現(xiàn)生成箭頭坐標(biāo)軸詳解
這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)生成箭頭坐標(biāo)軸,為坐標(biāo)軸增添箭頭,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下2022-03-03

