C++ 多线程的错误和如何避免(5)
要记得对加锁的临界区解锁
前提:在多个线程共享一块资源或者数据时,我们需要加上互斥锁来保护临界区(否则出现数据未定义的行为)
问题:我们往往在写了很多代码之后忘记 unlock 互斥锁,那么等待该资源的所有其他线程将被无限期地阻塞,程序可能会挂起
解决方法:使用 RAII 类型的 std::lock_guard 对象来自动释放锁,如下:
void CallHome(string message) { std::lock_guard<std::mutex> lock(mu); // Acquire the mutex cout << "Thread " << this_thread::get_id() << " says " << message << endl; } // lock_guard object is destroyed and mutex mu is released
当 lock_guard 对象被创建时,它拥有 mutex 的所有权;当 lock_guard 对象超出作用域,lock_guard 会被自动销毁并释放 mutex