日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

boost互斥锁_boost锁使用总结

發(fā)布時(shí)間:2025/3/12 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 boost互斥锁_boost锁使用总结 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。