【发布时间】:2015-11-10 10:25:59
【问题描述】:
是否可以将互斥锁、临界区等的所有权从第一个线程转移到第二个线程,同时不让任何第三个线程获取所有权? documentation for critical section 禁止在调用 EnterCriticalSection 的线程以外的线程中调用 LeaveCriticalSection:
如果一个线程在没有指定临界区对象的所有权时调用 LeaveCriticalSection,则会发生错误,可能导致另一个使用 EnterCriticalSection 的线程无限期等待。
但在我的场景中,我需要在与获取同步对象的线程不同的线程中准确释放同步对象,这样其他(第三个)线程就不能同时获得同步对象的所有权(从那一刻起)由第一个线程获取直到第二个线程释放的那一刻)。 C++ 线程或 WinAPI 调用中的解决方案将适合我的需要。
【问题讨论】:
-
不应该
std::move工作吗? -
@deW1 CiriticalSection 是 Windows 操作系统对象,而不是 C++ 类。
-
您可以使用第二个临界区(或其他同步对象)来保护两者之间的传输。但是,如果没有死锁的风险,很难做到正确。您确定需要这样做吗?
-
@deW1,来自en.cppreference.com/w/cpp/thread/mutex 的“std::mutex 既不可复制也不可移动”。此外,std::move 是关于在内存中移动对象,而不是关于在线程之间移动同步对象。例如。 unique_lock 是可移动的(在内存中
std::move,但它似乎不允许在线程之间移动互斥锁)。 -
But in my scenario I need to exactly release the synchronization object in a different thread than the one who acquired it- 关键部分根本不适合这种用途。您可以使用其他同步机制,例如semaphore:它没有所有权语义,因此可以被任何线程释放。
标签: c++ multithreading winapi mutex critical-section