自从我对程序进行了更改后我遇到了问题,这可能是由于线程本身调用了 joinable。在这种情况下到底发生了什么?
编辑: 我做了一些调试,问题是 Joinable 方法。
std::mutex threadMutex;
std::thread tAudioProcessingThread;
void getLock()
{
if (tAudioProcessingThread.joinable())
threadMutex.lock();
}
void releaseLock()
{
if (tAudioProcessingThread.joinable())
threadMutex.unlock();
}
函数 getLock()
和 releaseLock()
从两个现有线程调用。
在创建线程之前,我在调用 threadMutex.lock()
和 threadMutex.unlock()
函数时遇到了问题,所以我不得不创建这些替代函数,以便锁仅在线程存在时被调用。
最佳答案
一个线程本身不能 join()
,但是线程本身调用 joinable()
没有错。
t.joinable()
所做的只是测试 t.get_id() != std::thread::id{}
所以你选择哪个线程没有区别从中调用它。
关于c++ - 如果 std::thread 对自身调用 joinable 会发生什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26637913/