C++ 多執行緒的錯誤和如何避免(6)
阿新 • • 發佈:2022-05-19
加鎖的臨界區要儘可能的緊湊和小型
問題分析:
當一個執行緒在臨界區內執行時,所有其他試圖進入臨界區的執行緒都會被阻止,所以我們應該保證臨界區儘可能的小。比如,
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