C++ 多线程的错误和如何避免(6)

加锁的临界区要尽可能的紧凑和小型

问题分析:

当一个线程在临界区内执行时,所有其他试图进入临界区的线程都会被阻止,所以我们应该保证临界区尽可能的小。比如,

1
2
3
4
5
6
7
8
9
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 放进临界区内,比如,

1
2
3
4
5
6
7
8
9
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

  

 

posted @   strive-sun  阅读(47)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示