STL容器的執行緒安全?

科技探索者發表於2017-11-21

接上一篇STL容器刪除操作繼續,STL使用起來方便,還有自動記憶體管理,再結合合適的泛型演算法大大提高了我們程式設計的效率,於是我們“肆無忌憚”的使用在自己的程式中。但是隻要你有“肆無忌憚”的態度,你終歸是要走上彎路的,比如其執行緒安全問題。先從《Effective STL》進行搬運。

執行緒安全的情況

  • 多個讀取者是安全的。多執行緒可能同時讀取一個容器的內容,這將正確地執行。當然,在讀取時不能 有任何寫入者操作這個容器。

  • 對不同容器的多個寫入者是安全的。多執行緒可以同時寫不同的容器。

執行緒不安全的情況

  • 在對同一個容器進行多執行緒的讀寫、寫操作時。

  • 在每次呼叫容器的成員函式期間都要鎖定該容器。

  • 在每個容器返回的迭代器(例如通過呼叫begin或end)的生存期之內都要鎖定該容器。

  • 在每個在容器上呼叫的演算法執行期間鎖定該容器。

看到風險了吧?在工程中多執行緒操作STL的場景應該還是比較常見的,一個典型的例子就是用其來做生產者——消費者模型的佇列或者其他共享佇列,這樣為了應對執行緒安全問題我們必須自己對容器操作進行封裝。這是我自己實現的的封裝類threadSafe_container.h,另外書中給我們介紹了一種更通用的封裝方法,大家可以自己去參考實現

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
template<typename Container>    // 獲取和釋放容器的互斥量
class Lock {                    // 的類的模板核心;
public:                         // 忽略了很多細節
        Lock(const Containers container)
                        : c(container)
        {
                getMutexFor(c); // 在建構函式獲取互斥量
        }
        ~Lock()
        {
                releaseMutexFor(c); // 在解構函式裡釋放它
        }
private:
        const Container& c;
};
本文轉自永遠的朋友部落格51CTO部落格,原文連結http://blog.51cto.com/yaocoder/1208465如需轉載請自行聯絡原作者

yaocoder


相關文章