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