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

woaidongmao

文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數據加載中……

幾種線程鎖的效率比較(多線程,鎖,CRITICAL_SECTION)

測試環境Windows XP SP2,Intel Core2 Duo E8400 3.00GHz1.94GB內存

首先使用CRITICAL_SECTION和自旋機制實現:
CRITICAL_SECTION GCritical;
......
InitializeCriticalSectionAndSpinCount(&GCritical, 0x80000FA0);
......
//
線程核心函數,共使用兩個線程
for (int i = 0; i < 100000000; ++i)
{
    EnterCriticalSection(&GCritical);
    ++GlobalSum;
    LeaveCriticalSection(&GCritical);
}
......
DeleteCriticalSection(&GCritical);
實測時間為21.578s

使用CRITICAL_SECTION和非自旋機制:
CRITICAL_SECTION GCritical;
......
InitializeCriticalSection(&GCritical);
......
//
線程核心函數,共使用兩個線程
for (int i = 0; i < 100000000; ++i)
{
    EnterCriticalSection(&GCritical);
    ++GlobalSum;
    LeaveCriticalSection(&GCritical);
}
......
DeleteCriticalSection(&GCritical);
運行時間太長,在運行2分鐘后仍然未運行完畢

可見在大規模并行運算的環境中,如果存在臨界區,自旋鎖的時間開銷遠小于普通的鎖機制。相比于普通鎖,自旋鎖在進入操

作系統內核態之前會進行多次循環,并在循環中嘗試獲取鎖,如果在循環過程中自旋鎖獲得了鎖則自旋鎖所在線
程不必由用戶態陷入內核態,也不必交出自己的時間片進入等待狀態(見操作系統原理)。從而大大減少的獲取鎖的時間

有沒有比自旋鎖開銷更小的鎖機制呢?答案是有,下面就是一個利用X86 Interlock系列指令實現的win32用戶態鎖:
class CLocker
{
private:
_declspec(align(4)) volatile long m_lThreadId;
volatile long m_lLockCount;
int            m_iCollision;

public:
CLocker()
   :m_lThreadId(0)
   ,m_lLockCount(0)
   ,m_iCollision(0)
{}

~CLocker()
{
   if (m_lLockCount > 0)
    __debugbreak();
}

void Lock()
{
   const long tId = ::GetCurrentThreadId();
   if (tId == m_lThreadId)
   {
    ++m_lLockCount;
   }
   else
   {
    int iCol = 0;
    while (true)
    {
     ++iCol;
     if (_InterlockedCompareExchange(&m_lThreadId, tId, 0) == 0)
     {
      m_lLockCount = 1;
      if (iCol > m_iCollision)
       m_iCollision = iCol;
      return;
     }

     //volatile int delay;
     //const int maxDelay = (int)((rand() / (float)RAND_MAX) * 100) * 50;
     Sleep(0); //for (delay = 0; delay < maxDelay; ++delay); //
1
   }
}

void Release()
{
   const long tId = ::GetCurrentThreadId();
   if (tId == m_lThreadId)
   {
    if (--m_lLockCount == 0)
    {
     //_InterlockedExchange(&m_lThreadId, 0);
     m_lThreadId = 0;   //
這里不用Interlock操作,機器字對齊時寫入為原子操作
   }
}

int GetCollision()
{
   return m_iCollision;
}
};

該類通過Interlock系列指令集所具有的原子操作特性互斥的將臨界區資源交給獲得鎖的線程。所有操作均在用戶態執行,邏輯簡單,最終編譯結果指令數也非常少。極大提高了加鎖效率。注1處的循環是一個關鍵點。_InterlockedCompareExchange操作如果失敗會導致CPU執行復雜的Cache操作,從而浪費大量時間。使CAS失敗的線程等待,減少多線程爭用同一鎖時產生過多的_InterlockedCompareExchange操作失敗,從而提高加鎖效率。以下是測試結果

static CLocker GLocker;
......
//
線程核心函數,共兩個線程
for (int i = 0; i < 100000000; ++i)
{
GLocker.Lock();
++GlobalSum;
GLocker.Release();
}
......

測試結果為5.969s,可見用戶態鎖確實具有相對較高的效率。

需要說明的是,我的本意只是為了探討不同種類鎖的效率,實際情況中,多線程編程要盡量減少多線程間的資源爭用,從設計上避免頻繁加鎖解鎖(Lock-Free算法)

補充說明,windows平臺和xbox360平臺上的CriticalSection實際上包含一個內存屏障,保證臨界區前后的讀寫操作不會越界執行(見編譯器對指令的優化和CPU的指令亂序執行),一個InterlockedXxx操作,嵌套檢查,滿足特定條件向Mutex操作退化。CriticalSection使用合適的自旋次數能提高效率。CLocker由于沒有內存屏障實際上在某些情況下會不如CriticalSection安全,使用CLocker一定需要程序員自己保證內存操作的順序性。

實際上臨界區爭用導致線程等待的時間往往大于鎖執行的時間,優化加鎖解鎖速度實際上并未解決根本問題。

posted on 2011-05-14 02:03 肥仔 閱讀(8123) 評論(1)  編輯 收藏 引用 所屬分類: Windows開發

評論

# re: 幾種線程鎖的效率比較(多線程,鎖,CRITICAL_SECTION)  回復  更多評論   

I greatly appreciate your thoughts. For me these are significant things. Anyhow appreciate it. Good look over.
2011-05-14 14:52 | parker pen
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品久久久久久久久久直播| 久久亚洲国产精品日日av夜夜| 欧美日韩第一区日日骚| 日韩亚洲欧美成人| 99热在线精品观看| 国产视频久久| 欧美成人一区二区三区在线观看| 美女网站久久| 亚洲一区区二区| 久久国产一二区| 亚洲国产精品va在线观看黑人| 亚洲国产视频a| 国产精品久久久久国产a级| 久久精品午夜| 欧美区国产区| 久久久久这里只有精品| 欧美国产日韩一区二区在线观看| 中文av一区二区| 久久久久久日产精品| 亚洲午夜在线视频| 久久精品91久久久久久再现| 99国产一区二区三精品乱码| 销魂美女一区二区三区视频在线| 亚洲国产精品尤物yw在线观看| 一区二区三区四区五区在线| 伊人久久久大香线蕉综合直播| 亚洲精品专区| 亚洲第一网站免费视频| 国产精品99久久久久久人| 在线观看日韩av电影| 亚洲在线免费| 一区二区三区导航| 美女露胸一区二区三区| 欧美一区二区视频在线观看2020| 亚洲剧情一区二区| 久久精品成人欧美大片古装| 欧美高清一区| 六月婷婷久久| 国产欧美一区二区精品性| 亚洲另类自拍| 亚洲欧洲视频| 久久久久久**毛片大全| 欧美在线国产| 欧美性一区二区| 亚洲精品午夜精品| 91久久极品少妇xxxxⅹ软件| 久久午夜精品| 久久久久久穴| 国产日韩欧美在线播放不卡| 一区二区三区国产在线| 亚洲天堂成人| 欧美日韩一区二区在线播放| 亚洲国产婷婷综合在线精品| 一区二区在线不卡| 久久久久久噜噜噜久久久精品| 久久精品一本| 国外成人在线视频| 欧美在线视频二区| 欧美专区亚洲专区| 国产婷婷色一区二区三区| 欧美亚洲午夜视频在线观看| 欧美一区二区三区日韩视频| 国产精品尤物| 亚洲一区二区三区高清| 西西裸体人体做爰大胆久久久| 国产精品极品美女粉嫩高清在线| 野花国产精品入口| 先锋影音国产一区| 国产日韩精品一区二区三区在线| 欧美一区二区三区免费在线看| 久久精品一级爱片| 亚洲国产精品悠悠久久琪琪 | 亚洲免费视频一区二区| 欧美视频日韩视频| 亚洲午夜免费视频| 久久精品国产欧美亚洲人人爽| 国产午夜精品视频| 美女脱光内衣内裤视频久久网站| 亚洲第一区在线观看| 亚洲视屏一区| 国产日韩视频| 麻豆精品91| 一区二区三区四区蜜桃| 久久成人18免费观看| 在线免费观看日韩欧美| 欧美理论电影网| 亚洲综合99| 欧美大片18| 亚洲嫩草精品久久| 一区二区在线观看视频在线观看| 欧美日本亚洲| 午夜在线a亚洲v天堂网2018| 欧美高清在线观看| 午夜精品久久一牛影视| 亚洲国产综合91精品麻豆| 国产精品久久久久aaaa| 久久精品一区四区| 99re66热这里只有精品3直播 | 亚洲人体一区| 国产精品久久综合| 麻豆9191精品国产| 亚洲一品av免费观看| 狠狠色丁香婷综合久久| 久久精品国产久精国产一老狼| 亚洲第一视频网站| 久久精品中文| 亚洲无亚洲人成网站77777| 国产综合网站| 欧美性感一类影片在线播放| 久久综合伊人77777蜜臀| 中文国产成人精品久久一| 欧美成人免费网| 久久大香伊蕉在人线观看热2| 亚洲老板91色精品久久| 激情婷婷亚洲| 国产裸体写真av一区二区| 欧美日韩视频不卡| 欧美1级日本1级| 久久九九精品99国产精品| 亚洲一区在线免费| 日韩午夜激情av| 亚洲国产精品www| 久久亚洲捆绑美女| 欧美在线日韩精品| 亚洲欧美日韩国产| 中文一区二区在线观看| 亚洲精品影院在线观看| 亚洲国产欧美另类丝袜| 一区二区三区无毛| 国产一区二区三区在线播放免费观看| 国产精品v欧美精品v日本精品动漫 | 亚洲一区二区免费| 中文国产一区| 妖精视频成人观看www| 91久久久在线| 亚洲日韩成人| 99精品欧美一区二区三区综合在线| 亚洲国产精品精华液2区45| 在线播放亚洲| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美日韩亚洲高清| 欧美三区不卡| 国产精品久久久久一区二区三区共| 欧美日韩国产在线播放| 欧美三级黄美女| 欧美亚洲成人免费| 国产欧美韩日| 国内不卡一区二区三区| 伊甸园精品99久久久久久| 亚洲国产另类久久精品| 亚洲免费黄色| 亚洲欧美日韩国产中文| 欧美在线影院在线视频| 久热精品视频| 亚洲精品乱码久久久久久蜜桃91| 亚洲欧洲另类国产综合| 一本综合精品| 午夜在线视频观看日韩17c| 久久久99爱| 欧美乱大交xxxxx| 欧美性大战久久久久久久| 国产欧美一区二区在线观看| 亚洲成色999久久网站| 夜夜嗨av一区二区三区网站四季av| 亚洲免费影院| 欧美成人国产va精品日本一级| 亚洲激情一区| 先锋影音久久久| 欧美成人免费大片| 国产精品亚发布| 亚洲国产婷婷| 欧美亚洲免费在线| 欧美韩日一区| 亚洲中字在线| 欧美成年人视频网站欧美| 国产精品久久久久毛片软件| 韩日视频一区| 在线亚洲观看| 亚洲午夜久久久久久尤物| 国产区在线观看成人精品| 亚洲激情偷拍| 欧美一级视频免费在线观看| 亚洲国产精品美女| 亚洲欧美精品在线观看| 欧美女激情福利| 黄色成人av在线| 午夜精品久久久久久| 亚洲国产欧美在线| 欧美在线视频免费播放| 欧美日韩情趣电影| 91久久精品一区| 久久婷婷成人综合色| 亚洲性夜色噜噜噜7777| 欧美国产日韩a欧美在线观看| 国产日韩一区二区三区在线播放| 99热免费精品| 亚洲成人在线视频网站| 亚洲图片在线观看| 欧美成人精精品一区二区频| 午夜精品一区二区三区在线视|