假设有两个mutex(m1、m2),一个线程先锁住m1再锁住m2,另一个线程先锁住m2,再锁住m1,就有可能会出现死锁。std::lock内部使用了死锁避免的算法,可以有效避免死锁。有两种用法:
std::lock(m1, m2) std::lock_guard lock1(m1, std::adopt_lock) std::lock_guard lock2(m2, std::adopt_lock)
std::unique_lock lock1(m1, std::defer_lock); std::unique_lock lock2(m2, std::defer_lock); std::lock(lock1, lock2)
需要注意的是这两次调用std::lock的参数是不一样的。第一次传的是std::mutex,第二次则是std::unique_lock。这是由于std::adopt_lock与std::defer_lock的不同所造成的。假如第二次不传unique_lock而是传mutex。那么会造成程序hang!