日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

设计模式复习-单例模式

發布時間:2025/6/17 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 设计模式复习-单例模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

#pragma once #include "stdafx.h" #include<set> #include<string> #include<iostream> using namespace std;/* 設計模式-單例模式(Singleton)保證一個類僅有一個實例,并提供一個訪問它的全局訪問節點。 [懶漢模式涉及多線程上鎖問題,餓漢模式不涉及多線程上鎖問題] 下面實現懶漢跟餓漢模式,先不考慮上鎖問題,最后補充。 */ /* 設計模式-迭代器模式(Iterator) 提供一種方法順序訪問一個聚合對象中的各個元素,而不暴露該對象內部表示。 (現在好多語言都已經內置實現了這個功能了,所以實際用途不大, 但是建議寫一下,實現過程價值遠遠大于使用價值。) *///懶漢模式 class Cwork {private:static Cwork *m_cWork;static int m_nMarkRunCount;Cwork() {}//注意,構造函數私有化可以限制其他人去實例化這個類。void DoWrite() {cout << "WorkCiunt:" << m_nMarkRunCount++ << endl;} public:static void GetInstance() {if (m_cWork == NULL) {m_cWork = new Cwork();}}static void WrkteLog() {if (m_cWork == NULL) {cout << "no instance" << endl;return;}m_cWork->DoWrite();} };Cwork * Cwork::m_cWork = NULL; int Cwork::m_nMarkRunCount = 0;int main() {Cwork::WrkteLog();Cwork::GetInstance();Cwork::WrkteLog();getchar();return 0; }

?

#pragma once #include "stdafx.h" #include<set> #include<string> #include<iostream> using namespace std;//餓漢模式 class Cwork {private:static Cwork *m_cWork;static int m_nMarkRunCount;Cwork() {}//注意,構造函數私有化可以限制其他人去實例化這個類。void DoWrite() {cout << "WorkCiunt:" << m_nMarkRunCount++ << endl;} public:static Cwork* GetInstance() {if (m_cWork == NULL) {m_cWork = new Cwork();}return m_cWork;}static void WrkteLog() {if (m_cWork == NULL) {cout << "no instance" << endl;return;}m_cWork->DoWrite();} };Cwork * Cwork::m_cWork = Cwork::GetInstance(); int Cwork::m_nMarkRunCount = 0;int main() {Cwork::WrkteLog();Cwork::WrkteLog();getchar();return 0; }

還有就是鎖的問題。多線程環境下使用單例模式中的懶漢模式會涉及到上鎖問題,主要是在這個地方:

上面是一個傳統的上鎖模式,但是這個會有一個資源浪費問題,就是雖然m_cWork已經不等于NULL了,但是還是會不停的上鎖和解鎖,上鎖和解鎖涉及到內核態和用戶態的轉換,這回導致資源浪費。于是便引出了雙重鎖的概念,雙重鎖全稱雙重檢查鎖定模式,縮寫DCLP。

大體姿勢是這樣:

Static?void?GetInstance(){If(m_cWork?==?NULL){Lock{If(m_cWork?==?NULL){m_cWork?=?new?CWork();}}} }


但是繼續延伸一下,根據這里(

https://blog.csdn.net/nodeathphoenix/article/details/51657973

)的分析:雙重鎖也是不餓穩定的,那篇文章里引入了volatile來解決問題,感興趣的可以了解一下,我的思路是用匯編處理這個地方。不管用什么方式,注意一點,就是編譯器會對我們的代碼進行優化。也就是變換了很多姿勢,最后轉出來的匯編是一樣的。這個地方要注意。

?

?

總結

以上是生活随笔為你收集整理的设计模式复习-单例模式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。