青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

西城

指尖代碼,手上年華

聯(lián)系 聚合 管理
  20 Posts :: 0 Stories :: 62 Comments :: 0 Trackbacks
在看POCO網(wǎng)絡(luò)庫的時候,其中實現(xiàn)了一個singleton模式,提到了DCLP的不可行性。就去查閱了一下,
找到了這篇文章。原文太長,將其意思大略整理如下。

singleton差不多是所有設(shè)計模式中最為常見的一個,但卻不是線程安全的。
DCLP就是為了消除此缺點而設(shè)計出來的——Double Checked Locking Pattern。但卻仍然是
不可靠的。


一般的singleton實現(xiàn)為:
// from the header file
class Singleton {
public:
static Singleton* instance();

private:
static Singleton* pInstance;
};
// from the implementation file
Singleton* Singleton::pInstance = 0;
Singleton* Singleton::instance() {
if (pInstance == 0) {                //Line 1
   pInstance=new Singleton;         //Line 2
}
return pInstance;
}
單線程模式下,這種方法工作的很好。但在多線程模式下卻是有問題的。
假設(shè)線程A進入了instance函數(shù),執(zhí)行到Line 1,然后被掛起。當它被掛起的時候,它
剛測得pInstance是NULL,所以還沒有Singleton對象被創(chuàng)造出來。
然后線程B進入instance并且執(zhí)行到line1,發(fā)現(xiàn)pInstance是NULL,然后執(zhí)行下一句,創(chuàng)建了一個
Singleton并且使pInstance指向它。然后返回pInstance.
當線程A繼續(xù)執(zhí)行的時候,它會執(zhí)行Line2,創(chuàng)建一個Singleton并使pInstance指向它,這就
破壞了singleton的意義,因為創(chuàng)建了兩個singleton.
要想使其是線程安全的,需要在測試pInstance之間加一個lock.
Singleton* Singleton::instance() {
Lock lock;
// acquire lock (params omitted for simplicity)
if (pInstance == 0) {
pInstance = new Singleton;
}
return pInstance;
}
// release lock 

這樣有一個和很大的缺點——代價太高,每次訪問都需要一個lock.但實際上,我們只需要在
第一次創(chuàng)建的時候加一個鎖,而且應(yīng)該是instance第一次被調(diào)用的時候。如果在運行時
instance被調(diào)用了n次,我們只需要在第一次調(diào)用的時候加鎖就可以了。DCLP就是為了
解決這個問題而設(shè)計的--------------去掉那些不必要的LOCK。
Singleton* Singleton::instance() {
if (pInstance == 0) {
// 1st test
Lock lock;
if (pInstance == 0) {
// 2nd test
pInstance = new Singleton;
}
}
return pInstance;
}
DCLP在加鎖之前先測試pInstance是否為空,盡在其為NULL時才會需要一個LOCK,第二次測試也是
必要的,因為有可能另一個線程在第一次測試pInstance和請求LOCK時執(zhí)行了new.

問題之所在:
pInstance=new Singleton;分為以下三步:
1.分配內(nèi)存(sizeof(Singleton).
2.在分配的內(nèi)存上創(chuàng)建一個Singleton對象。
3.讓pInstance指向這塊內(nèi)存。問題就在于編譯器不一定按照順序執(zhí)行這三步。 有時候編譯器會將
第二步和第三步互換。此時情況可能如以下所示:
Singleton* Singleton::instance() {
if (pInstance == 0) {
Lock lock;
if (pInstance == 0) {
pInstance =
// Step 3
operator new(sizeof(Singleton)); // Step 1
// Step 2
new (pInstance) Singleton;
}
}
return pInstance;
}
在實際的DCLP代碼中,step2是可能拋出異常的,這時需要保證pInstance沒有變化(setp3未
執(zhí)行)。所以一般并不能把step3移到step2之前,但有時候是可以的,比如說step2并不拋出異
常。
現(xiàn)在如果線程A進入instance,進行第一次測試,請求了一個LOCK,然后執(zhí)行了step1和step3.
然后被掛起。此時pInstance是NO-NULL,但是沒有singleton對象被創(chuàng)建出來。
然后,線程B進入instance,發(fā)現(xiàn)pInstance非空,然后將其返回,然后解引用,但是卻沒有對象。
所以,DCLP只有在step1和step2在step3之前完成的情況下才能正常工作,但C/C++并不提供這樣的
保證。
posted on 2012-04-20 20:20 西城 閱讀(6820) 評論(7)  編輯 收藏 引用 所屬分類: C/C++

Feedback

# re: 為什么DCLP是不可行的?(1) 2012-04-21 10:36 runner.mei
說了半天,無非是想法要為 pInstance 加上 violate 修飾符嘛, 最新的 vc++ 和 gcc 都擴展了 violate 的語義, 保證了它的原子性(Atomicity)和順序性(Ordering)了。DCLP是可行的  回復(fù)  更多評論
  

# re: 為什么DCLP是不可行的?(1) 2012-04-21 10:39 runner.mei
說了半天,無非是想說要為 pInstance 加上 violate 修飾符嘛, 最新的 vc++ 和 gcc 都擴展了 violate 的語義, 保證了它的原子性(Atomicity)和順序性(Ordering)了。DCLP是可行的。
已經(jīng)不是原創(chuàng)了,還分成幾篇,賺點擊。  回復(fù)  更多評論
  

# re: 為什么DCLP是不可行的?(1) 2013-03-15 11:32 Eric.Tsai

pInstance = new Singleton;
改成
Singleton *pTemp = new Singleton;
pInstance = pTemp;
不就可以避免了嗎? 還是我理解不夠透徹?  回復(fù)  更多評論
  

# re: 為什么DCLP是不可行的?(1) 2013-03-15 11:44 Eric.Tsai
看了原文才知道忘記"編譯器優(yōu)化了"@Eric.Tsai
  回復(fù)  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久人人精品| 狂野欧美性猛交xxxx巴西| 欧美激情视频一区二区三区在线播放 | 亚洲精选视频免费看| 毛片一区二区三区| 久久综合网络一区二区| 精品成人国产在线观看男人呻吟| 久久中文字幕一区| 欧美激情亚洲精品| 中文日韩在线视频| 亚洲一区视频在线观看视频| 国产精品视频专区| 久久久久天天天天| 裸体一区二区三区| 久热成人在线视频| av不卡在线观看| 亚洲永久免费av| 亚洲大胆美女视频| 亚洲美女免费视频| 国产午夜精品一区二区三区视频| 久久亚洲免费| 欧美日产在线观看| 久久成人精品视频| 欧美国产视频在线| 欧美一二三区精品| 免费观看成人鲁鲁鲁鲁鲁视频| 99国产精品99久久久久久粉嫩| 亚洲一区二区高清视频| 激情综合亚洲| 亚洲深夜福利网站| 亚洲观看高清完整版在线观看| 日韩亚洲视频在线| 亚洲福利视频在线| 午夜久久资源| 一本色道久久综合亚洲精品不 | 久久免费精品日本久久中文字幕| 免费成人高清| 欧美一区高清| 欧美日韩亚洲综合一区| 老牛嫩草一区二区三区日本| 国产精品超碰97尤物18| 亚洲大黄网站| 国产人成一区二区三区影院| 91久久线看在观草草青青| 国产一区二区三区久久悠悠色av | 亚洲精品一区二区三区樱花| 国产欧美一区二区精品性 | 亚洲女女女同性video| 免费在线欧美黄色| 久久久久免费视频| 国产精品一区二区三区免费观看 | 欧美高清视频| 国内自拍亚洲| 亚洲欧美中文日韩v在线观看| 99视频+国产日韩欧美| 猫咪成人在线观看| 久久综合给合久久狠狠狠97色69| 国产精品国产三级国产a| 亚洲免费视频网站| 欧美日本国产视频| 亚洲国产另类久久精品| 亚洲第一在线视频| 久久久精品国产一区二区三区 | 久久精品观看| 国产精品香蕉在线观看| 一区二区精品在线| 亚洲一区二区三区中文字幕| 欧美啪啪成人vr| 亚洲人成人77777线观看| 亚洲精品一区二区三区樱花| 久久综合国产精品| 欧美风情在线观看| 亚洲精品女人| 欧美日韩一区二区三区高清| 一区二区精品国产| 欧美一级淫片aaaaaaa视频| 国产精品爽爽ⅴa在线观看| 亚洲午夜精品久久久久久app| 亚洲一区二区免费视频| 国产精品草草| 欧美一区二区在线免费播放| 久久一区二区三区四区五区| 狠狠色综合色区| 欧美1区2区视频| 亚洲美女视频在线观看| 亚洲免费在线播放| 激情综合电影网| 欧美电影免费| 亚洲视频导航| 美女主播视频一区| 亚洲精品自在在线观看| 欧美日韩亚洲综合一区| 亚洲欧美偷拍卡通变态| 久久永久免费| 夜夜嗨av一区二区三区免费区| 欧美日韩在线不卡一区| 亚洲欧美网站| 亚洲国产天堂久久综合| 亚洲欧美日韩成人高清在线一区| 国产在线一区二区三区四区| 欧美成人综合| 香蕉乱码成人久久天堂爱免费| 蜜臀av性久久久久蜜臀aⅴ| 一区二区av在线| 狠狠色综合播放一区二区| 欧美美女视频| 久久久久久国产精品mv| 亚洲精品一区二区三区樱花| 久久精品免费| 一区二区三区导航| 怡红院精品视频在线观看极品| 欧美另类亚洲| 久久久久久久波多野高潮日日| 亚洲日韩欧美一区二区在线| 欧美一区三区三区高中清蜜桃| 亚洲第一区色| 国产亚洲一区二区三区| 欧美日韩视频专区在线播放 | 欧美午夜精品伦理| 久久综合久久综合这里只有精品 | 亚洲免费综合| 亚洲精品日韩综合观看成人91| 久久久久久久999精品视频| 一本色道久久综合一区| 在线电影院国产精品| 国产精品系列在线播放| 欧美三区在线| 欧美日韩性视频在线| 欧美国产综合| 蜜桃av一区二区| 久久久久久久久久久久久久一区| 亚洲一区二区免费看| 夜夜嗨av一区二区三区网页| 亚洲国产日韩综合一区| 欧美福利精品| 免费在线欧美视频| 久热国产精品| 免费日韩视频| 男人的天堂成人在线| 免费观看不卡av| 欧美国产精品人人做人人爱| 麻豆av一区二区三区| 久久精品综合| 久久影音先锋| 欧美成人一区二区三区片免费| 美女被久久久| 欧美国产成人精品| 亚洲第一久久影院| 欧美风情在线观看| 亚洲黄色在线视频| 99av国产精品欲麻豆| 亚洲精品韩国| 亚洲一区精彩视频| 欧美中文字幕在线观看| 久久免费国产精品| 免费看av成人| 欧美日韩国产麻豆| 国产精品jizz在线观看美国| 国产精品欧美在线| 国产在线精品成人一区二区三区 | 亚洲精品视频在线观看免费| 亚洲三级免费观看| 亚洲深夜福利在线| 欧美在线看片a免费观看| 羞羞漫画18久久大片| 久久久五月婷婷| 久久综合网色—综合色88| 欧美成人精品在线观看| 亚洲黄色免费电影| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲一区二区三区午夜| 欧美一区二区三区精品电影| 久久婷婷麻豆| 欧美亚日韩国产aⅴ精品中极品| 国产精品一区二区久久久久| 揄拍成人国产精品视频| av成人免费在线| 久久成人免费网| 亚洲第一在线| 在线亚洲高清视频| 久久视频一区二区| 欧美日韩在线视频观看| 国产一区视频在线观看免费| 91久久中文| 在线观看亚洲精品| 亚洲天堂av图片| 免费日韩精品中文字幕视频在线| 一区二区欧美在线观看| 久久久久久综合| 国产精品国产三级国产aⅴ入口| 韩日精品中文字幕| 亚洲综合色在线| 亚洲福利视频专区| 欧美一区=区| 欧美午夜一区二区三区免费大片| 精品av久久707| 久久gogo国模裸体人体| 亚洲精品一区二区三区婷婷月| 久久狠狠亚洲综合| 国产精品网红福利|