Mor*_*que 31 c++ concurrency mutex locking
我应该何时更喜欢第一段代码到第二段,并且它们有根本区别
std::mutex mtx;
mtx.lock();
... //protected stuff
mtx.unlock();
... //non-protected stuff
mtx.lock();
... //etc
Run Code Online (Sandbox Code Playgroud)
和
std::mutex mtx;
std::unique_lock<std::mutex> lck(mtx);
... //protected stuff
lck.unlock();
... //non-protected stuff
lck.lock();
... //etc
Run Code Online (Sandbox Code Playgroud)
我知道lock_guard基本上是一个没有锁定和解锁功能的unique_lock,但是我很难用互斥锁来区分互斥锁和锁.
gbe*_*har 31
是的,这些std::unique_lock调用在析构函数中的互斥锁上解锁.
这样做的好处是,如果抛出一些异常,您确定在离开std::unique_lock定义范围的位置时互斥锁将解锁.
Ric*_*ges 11
想一想:
// define a mutex
std::mutex mtx;
Run Code Online (Sandbox Code Playgroud)
... 很久以后 ...
void something_safe()
{
// code in these braces is a critical section
{
auto lock = std::unique_lock<std::mutex>(mtx); // equivalent to mtx.lock();
... //protected stuff
} // <---- however you leave this brace, equivalent to mtx.unlock();
... //non-protected stuff
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13984 次 |
| 最近记录: |