【发布时间】:2018-05-10 16:26:15
【问题描述】:
关于unique_lock,我遇到了一些奇怪的行为。创建它后,我尝试调用解锁,但它使我的程序崩溃。我创建了一个最小的示例,该示例始终在解锁功能上崩溃(使用 gdb 进行确认)。
#include <iostream>
#include <string>
#include <mutex>
#include <thread>
#include <chrono>
std::mutex myMutex;
void lockMe()
{
std::unique_lock lock(myMutex);
std::cout << "Thread\n";
}
int main()
{
std::unique_lock lock(myMutex);
auto c = std::thread(lockMe);
std::this_thread::sleep_for(std::chrono::seconds(1));
std::cout << "Main\n";
myMutex.unlock();
c.join();
return 0;
}
谁能解释为什么会这样?
【问题讨论】:
-
en.cppreference.com/w/cpp/thread/unique_lock/unlock - 如果互斥锁未锁定则抛出,当你解锁它时它不会。
-
您知道没有必要手动解锁已被
unique_lock锁定的互斥锁? -
您能解释一下为什么要显式解锁互斥锁吗?另外,你能说出你认为“unique”这个词在“unique_lock”中使用的含义吗?这里的问题在于您对一些基本概念的误解,但不清楚您被误导的概念是什么,所以请告诉我们更多信息,我们可以消除您的误解。
-
这实际上是一个错误,确实是错误。但在实际问题中,我改为调用锁来解锁,这就是导致错误的原因。
-
特别是,您的问题与您的代码不匹配。您的问题是“为什么解锁独特的锁会崩溃?”但您并没有解锁唯一的锁。您正在解锁互斥锁。你能解释一下问题和代码之间的差异吗?
标签: c++ multithreading locking mutex