void lock();
概要
共有ロックを取得する
効果
pm->lock_shared();
※pm
はメンバ変数として保持している、ミューテックスオブジェクトへのポインタ
事後条件
owns_lock() == true
戻り値
なし
例外
この関数は、pm->lock()
関数内で投げられうるあらゆる例外を投げる可能性がある。
そのほかに、以下のerror conditionを持つsystem_error
例外オブジェクトを送出する可能性がある:
operation_not_permitted
:pm
がNULL
resource_deadlock_would_occur
:owns_lock() == true
の状態でこの関数が呼び出された
例
#include <cassert>
#include <shared_mutex>
int main()
{
std::shared_timed_mutex mtx;
{
// 遅延ロックする(ここではロックを取得しない)
std::shared_lock<std::shared_timed_mutex> lock(mtx, std::defer_lock);
// 共有ロックを取得する
lock.lock();
assert(lock.owns_lock() == true);
}
}
17
#include <cassert>
#include <shared_mutex>
int main()
{
std::shared_timed_mutex mtx;
{
// 遅延ロックする(ここではロックを取得しない)
std::shared_lock<std::shared_timed_mutex> lock(mtx, std::defer_lock);
// 共有ロックを取得する
lock.lock();
assert(lock.owns_lock() == true);
}
}
出力
バージョン
言語
- C++14
処理系
- Clang: 3.5 ✅
- GCC: 4.9 ✅
- ICC: ??
- Visual C++: 2015 ✅