- mutex[meta header]
- std[meta namespace]
- timed_mutex[meta class]
- function[meta id-type]
- cpp11[meta cpp]
void lock();ロックを取得する
この関数を呼び出したスレッドが、ミューテックスの所有権を保持していないこと
この関数を呼び出したスレッドがミューテックスの所有権を取得できるまでブロックする
なし
この関数は、以下のerror conditionを持つsystem_error例外オブジェクトを送出する可能性がある:
operation_not_permitted: スレッドにこの操作を行う権限がないresource_deadlock_would_occur: デッドロックが発生することを検出した(実装依存)- C++14まで :
device_or_resource_busy: ミューテックスがすでにロックされていて、ブロッキングできない
#include <iostream>
#include <thread>
#include <mutex>
class X {
std::timed_mutex mtx_;
int value_ = 0;
public:
// メンバ変数value_への書き込みを排他的にする
void add_value(int value)
{
mtx_.lock(); // ロックを取得する
value_ = value;
mtx_.unlock(); // ロックを手放す
}
};
int main()
{
X x;
std::thread t1([&x]{ x.add_value(1); });
std::thread t2([&x]{ x.add_value(2); });
t1.join();
t2.join();
}- lock()[color ff0000]
- mtx_.unlock()[link unlock.md]
- C++11
- Clang: ??
- GCC: 4.7.0 [mark verified]
- ICC: ??
- Visual C++: 2012 [mark verified], 2013 [mark verified], 2015 [mark verified]
- LWG Issue 2309.
mutex::lock()should not throwdevice_or_resource_busy- C++17以降、この関数から
device_or_resource_busyが送出される可能性がなくなった。デッドロックが検出できればbusyではなくresource_deadlock_would_occurが送出されるべき。busyの検出はmutexクラスではなくcondition_variable::wait()で行うこと
- C++17以降、この関数から