boost::mutex提供了跨平臺(tái)的鎖操作,不允許多個(gè)線程同時(shí)訪問共享資源,從而確保共享資源不被臟寫。在本文中僅僅是介紹簡(jiǎn)單的兩種鎖,最高效的鎖boost::mutex和區(qū)域鎖boost::mutex::scoped_lock
創(chuàng)新互聯(lián)為企業(yè)級(jí)客戶提高一站式互聯(lián)網(wǎng)+設(shè)計(jì)服務(wù),主要包括成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)、app軟件開發(fā)公司、重慶小程序開發(fā)公司、宣傳片制作、LOGO設(shè)計(jì)等,幫助客戶快速提升營銷能力和企業(yè)形象,創(chuàng)新互聯(lián)各部門都有經(jīng)驗(yàn)豐富的經(jīng)驗(yàn),可以確保每一個(gè)作品的質(zhì)量和創(chuàng)作周期,同時(shí)每年都有很多新員工加入,為我們帶來大量新的創(chuàng)意。
boost::mutex例子
#include
boost::mutex m_mutexAccessServiceManager;
void CSettingCenter::ClearPlatformServiceInfoCache()
{
m_mutexAccessServiceManager.lock();
m_mapAccessServiceManager.clear();
m_mutexAccessServiceManager.unlock();
}
區(qū)域鎖boost::mutex::scoped_lock顧名思義就是在作用域內(nèi)有效,當(dāng)離開作用域自動(dòng)釋放鎖,傳遞參數(shù)是鎖。區(qū)域鎖就是把鎖封裝到一個(gè)對(duì)象里面。鎖的初始化放到構(gòu)造函數(shù),鎖的釋放放到析構(gòu)函數(shù)。這樣當(dāng)鎖離開作用域時(shí),
析構(gòu)函數(shù)會(huì)自動(dòng)釋放鎖。即使運(yùn)行時(shí)拋出異常,由于析構(gòu)函數(shù)仍然會(huì)自動(dòng)運(yùn)行,所以鎖仍然能自動(dòng)釋放。一個(gè)典型的區(qū)域鎖
void test()
{
boost::mutex::scoped_lock lock(m_mutexAccessServiceManager);
m_mapAccessServiceManager.clear();
}
應(yīng)用于有大量的return返回的代碼,避免出現(xiàn)死鎖的問題
擴(kuò)展
std::scoped_lock提供了可變參數(shù)長(zhǎng)度的構(gòu)造器,接收多個(gè)鎖。允許在可能導(dǎo)致死鎖的狀態(tài)下,對(duì)多個(gè)互斥量加鎖。例如:
{
??? // safely locked as if using std::lock
??? std::scoped_lock
}
目前std::lock_guard已經(jīng)被廢棄,GCC7已經(jīng)完整支持
friend void swap(X& lhs, X& rhs)
{
??? if (&lhs == & rhs)
??????? return;
??? std::lock(lhs.m, rhs.m);
??? std::lock_guard
??? std::lock_guard
??? swap(lhs.some_detail, rhs.some_detail);
}
friend void swap(X& lhs, X& rhs)
{
??? if (&lhs == &rhs)
??????? return;
??? std::scoped_lock guard(lhs.m, rhs.m);
??? swap(lhs.some_detail, rhs.some_detail);
}
引用
https://stackoverflow.com/questions/43019598/stdlock-guard-or-stdscoped-lock