C++ Primer筆記(2)

來源:互聯網
上載者:User

關鍵段:
CRITICAL_SECTION g_cs;
EnterCriticalSection(&g_cs);
//加入訪問共用資源的代碼
LeaveCriticalSection(&g_cs);
由於關鍵段中使用了Interlocked函數,因此執行速度非常快。
最大的缺點在於它們無法用來在多個進程之間對線程進行同步。
一般把CRITICAL_SECTION結構作為全域變數來分配,這樣進程中的所有線程就能夠非常方便地通過這些變數名來訪問這些結構。
在EnterCriticalSection前必須先調用InitializeCriticalSection對g_cs初始化,當不需要的時候,用DeleteCriticalSection來刪除。
使用關鍵段比輪循的優勢在於等待過程中不會浪費CPU時間。

關鍵段與旋轉鎖:
Q1:在使用關鍵段的同時,為什麼要加旋轉鎖?
A1:當線程試圖進入一個關鍵段,但這個關鍵段正被另一個進程佔用的時候,函數會立即把調用線程切換到等待狀態。這意味著
線程必須從使用者模式切換到核心模式(大約要1000個CPU周期),這個切換的開銷非常大。為了提高關鍵段的效能,Mircrosoft把旋轉鎖合并
到了關鍵段中。因此,當調用EnterCriticalSection的時候,它會用一個旋轉鎖不斷地迴圈,嘗試在一段時間內獲得對資源的訪問權。
只有當失敗的時候,線程才會切換到核心模式並進入等待狀態。
為了使用關鍵段的時候同時使用旋轉鎖,我們必須調用下面的函數來初始化關鍵段
BOOL InitializeCriticalSectionAndSpinCount(PCRITICAL_SECTION pcs,DWORD dwSpinCount);
pcs----關鍵段地址,dwSpinCount----旋轉鎖嘗試次數(單一處理器的機器會忽略這個參數)
改變旋轉次數:
DWORD SetCriticalSectionSpinCount(PCRITICAL_SECTION pcs,DWORD dwSpinCount);
自己可以嘗試各種值,4000可做為一個參考。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.