boost互斥锁_boost锁使用总结
boost鎖的概述:
boost庫(kù)中提供了mutex類(lèi)與lock類(lèi),通過(guò)組合可以輕易的構(gòu)建讀寫(xiě)鎖與互斥鎖。
舉個(gè)通俗的例子,如果共享資源是一個(gè)自動(dòng)鎖住的房間,互斥體是鑰匙,進(jìn)入房間必須取鑰匙,離開(kāi)房間應(yīng)該還鑰匙。這就對(duì)應(yīng)著互斥體的lock(取鑰匙)和unlock(還鑰匙)。
動(dòng)態(tài)分配內(nèi)存存在類(lèi)似的情況。如果忘記delete,會(huì)導(dǎo)致內(nèi)存泄漏。它是如何解決的?在棧上分配對(duì)象,要一個(gè)特點(diǎn),那就是離開(kāi)作用域后,對(duì)象肯定要調(diào)用析構(gòu)方法。利用這個(gè)特點(diǎn),可以使用對(duì)象對(duì)指針?lè)庋b,在對(duì)象的析構(gòu)方法中進(jìn)行delete,就保證了一定會(huì)執(zhí)行delete。這就是智能指針。因?yàn)橹悄苤羔?#xff0c;不是針對(duì)一個(gè)特定類(lèi)型的指針,因此把智能指針設(shè)計(jì)為類(lèi)的模版,根據(jù)模版實(shí)參特例化一個(gè)模板類(lèi)。同樣道理,也可以使用相同技術(shù),對(duì)互斥體封裝。這就是lock類(lèi)模版。在lock的構(gòu)造方法調(diào)用互斥體的lock方法,在lock的析構(gòu)方法調(diào)用互斥體的unlock方法。mutex是對(duì)象類(lèi),lock是模板類(lèi)。
mutex對(duì)象類(lèi):
mutex類(lèi)主要有兩種:boost::mutex,boost::shared_mutex,其中mutex有l(wèi)ock和unlock方法,shared_mutex除了提供lock和unlock方法外,還有shared_lock和shared_unlock方法。因此,boost::mutex為獨(dú)占互斥類(lèi),boost::shared_mutex為共享互斥類(lèi)。
lock模板類(lèi):
boost::unique_lock,boost::shared_lock,其中unique_lock為獨(dú)占鎖,shared_lock為共享鎖。unique_lock中的T可以為mutex類(lèi)中的任意一種,如果為shared_mutex,那么boost::unique_lock<:shared_mutex>類(lèi)的對(duì)象構(gòu)造函數(shù)構(gòu)造時(shí),會(huì)自動(dòng)調(diào)用shared_mutex的shared_lock方法,析構(gòu)函數(shù)里,會(huì)自動(dòng)調(diào)用shared_mutex的shared_unlock方法。如果是boost::
unique_lock<:mutex>,則分別自動(dòng)調(diào)用lock和unlock方法。
boost::shared_lock中的T只能是shared_mutex類(lèi)。
讀寫(xiě)鎖的實(shí)現(xiàn):
typedefboost::shared_lock<:shared_mutex> readLock;
typedef boost::unique_lock<:shared_mutex> writeLock;
boost::shared_mutex?rwmutex;
void readOnly( )
{
readLock? rdlock( rwmutex );
/// do something
}
void writeOnly( )
{
writeLock? wtlock( rwmutex );
/// do something
}
對(duì)同一個(gè)rwmutex,線程可以同時(shí)有多個(gè)readLock,這些readLock會(huì)阻塞任意一個(gè)企圖獲得writeLock的線程,直到所有的readLock對(duì)象都析構(gòu)。如果writeLock首先獲得了rwmutex,那么它會(huì)阻塞任意一個(gè)企圖在rwmutex上獲得readLock或者writeLock的線程。boost::shared_lock使用要小心,千萬(wàn)不要同一個(gè)線程多次進(jìn)入。
互斥鎖的實(shí)現(xiàn):
typedef boost::unique_lock<:mutex> exclusiveLock;
遞歸式的互斥量:
boost::recursive_mutex提供一個(gè)遞歸式的互斥量。對(duì)于一個(gè)實(shí)例最多允許一個(gè)線程擁有其鎖定,如果一個(gè)線程已經(jīng)鎖定一個(gè)boost::recursive_mutex實(shí)例,那么這個(gè)線程可以多次鎖定這個(gè)實(shí)例。
boost::mutex::scoped_lock
boost::mutexio_mutex;
void foo( )
{
{
boost::mutex::scoped_lock lock( io_mutex);???????? ///鎖定
} ///解鎖
}
總結(jié)
以上是生活随笔為你收集整理的boost互斥锁_boost锁使用总结的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 树莓派的使用
- 下一篇: TensorFlow 笔记4--使用te