std::mutex必须配合RAII类(如std::lock_guard或std::unique_lock)使用,裸调lock()/unlock()易因异常、提前return等导致死锁;多锁需统一顺序或用std::scoped_lock避免AB-BA死锁;mutex不可复制移动,应为private成员并禁用拷贝;递归需求才用std::recursive_mutex;关键在合理界定共享数据与临界区粒度。

C++怎么使用互斥锁_C++多线程安全教程【同步】

std::mutex 必须配合 std::lock_guard 或 std::unique_lock 使用

直接调用 mutex.lock()mutex.unlock() 极易出错——忘记 unlock、提前 return、抛异常都会导致死锁。C++ 标准库不推荐裸调用,而是靠 RAII 自动管理生命周期。

实操建议:

多个 mutex 加锁顺序不一致会引发死锁

两个线程分别按不同顺序获取 mtx_amtx_b,比如线程1先锁 a 再锁 b,线程2先锁 b 再锁 a,就可能互相等待对方释放——典型 AB-BA 死锁。

实操建议:

std::mutex 不可复制、不可移动,别传值或存 vector

常见错误:把 std::mutex 成员变量设为 public,然后意外被拷贝;或试图 std::vector —— 编译直接失败,因为 std::mutex 删除了拷贝和移动构造函数。

实操建议:

递归锁不是默认选项,std::recursive_mutex 要主动选

有些场景确实需要同一线程多次进入临界区(比如递归函数调用),但 std::mutex 不支持。有人误以为“加锁两次就自动递归”,结果程序卡死。

实操建议:

真正难的不是写对 lock/unlock,而是判断哪段数据算“共享”、哪个粒度该加锁、以及锁住之后是否还调用了可能阻塞或抛异常的第三方代码——这些地方一漏,std::mutex 就成了幻觉。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。