程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> STL容器的線程安全?

STL容器的線程安全?

編輯:關於C語言

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

線程安全的情況

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

  • 對不同容器的多個寫入者是安全的。多線程可以同時寫不同的容器。

線程不安全的情況

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

  • 在每次調用容器的成員函數期間都要鎖定該容器。

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

  • 在每個在容器上調用的算法執行期間鎖定該容器。

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

template<typename Container>    // 獲取和釋放容器的互斥量
class Lock {                    // 的類的模板核心;
public:                         // 忽略了很多細節
        Lock(const Containers container)
                        : c(container)
        {
                getMutexFor(c); // 在構造函數獲取互斥量
        }
        ~Lock()
        {
                releaseMutexFor(c); // 在析構函數裡釋放它
        }
private:
        const Container& c;
};


本文出自 “永遠的朋友” 博客,請務必保留此出處http://yaocoder.blog.51cto.com/2668309/1208465

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved