1. 程式人生 > 其它 >C++ 多執行緒的錯誤和如何避免(6)

C++ 多執行緒的錯誤和如何避免(6)

加鎖的臨界區要儘可能的緊湊和小型

問題分析:

當一個執行緒在臨界區內執行時,所有其他試圖進入臨界區的執行緒都會被阻止,所以我們應該保證臨界區儘可能的小。比如,

void CallHome(string message)
{
  std::lock_guard<std::mutex> lock(mu); // Start of Critical Section - to protect std::cout

  ReadFifyThousandRecords();

  cout << "Thread " << this_thread::get_id() << " says " << message << endl;

}// lock_guard object is destroyed and mutex mu is released

  

ReadFifyThousandRecords() 方法是一個只讀操作,沒有任何理由讓它在鎖內執行,如果它需要花費 10s 從一個 DB 

中讀取五萬次記錄的話,那所有其他的執行緒會被這段並不需要的時間給阻塞。它將嚴重影響程式的執行效率。

正確的方式應該是隻把 std::cout 放進臨界區內,比如,

void CallHome(string message)
{
  ReadFifyThousandRecords(); // Don't need to be in critical section because it's a read only operation

  std::lock_guard<std::mutex> lock(mu); // Start of Critical Section - to protect std::cout

  cout << "Thread " << this_thread::get_id() << " says " << message << endl;

}// lock_guard object is destroyed and mutex mu is released