- shared_mutex[meta header]
- std[meta namespace]
- shared_lock[meta class]
- function template[meta id-type]
- cpp14[meta cpp]
template <class Rep, class Period>
bool try_lock_for(const chrono::duration<Rep, Period>& rel_time);
タイムアウトする相対時間を指定して共有ロックの取得を試みる
pm->try_lock_for_shared(rel_time);
※pm
はメンバ変数として保持している、ミューテックスオブジェクトへのポインタ
owns_lock()
の値が、pm->try_lock_for_shared(rel_time)
の戻り値になること
pm->try_lock_for_shared(rel_time)
の戻り値が返る
この関数は、pm->try_lock_for_shared()
関数内で投げられうるあらゆる例外を投げる可能性がある。
そのほかに、以下のerror conditionを持つsystem_error
例外オブジェクトを送出する可能性がある:
operation_not_permitted
:pm
がNULL
resource_deadlock_would_occur
:owns_lock()
== true
の状態でこの関数が呼び出された
#include <cassert>
#include <system_error>
#include <chrono>
#include <shared_mutex>
int main()
{
std::shared_timed_mutex mtx;
{
// 遅延ロックする(ここではロックを取得しない)
std::shared_lock<std::shared_timed_mutex> lock(mtx, std::defer_lock);
// 共有ロックの取得を試みる(3秒でタイムアウト)
if (!lock.try_lock_for(std::chrono::seconds(3))) {
// 共有ロックの取得に失敗
std::error_code ec(static_cast<int>(std::errc::device_or_resource_busy), std::generic_category());
throw std::system_error(ec);
}
assert(lock.owns_lock() == true);
}
}
- try_lock_for[color ff0000]
- std::shared_timed_mutex[link /reference/shared_mutex/shared_timed_mutex.md]
- std::defer_lock[link /reference/mutex/defer_lock.md]
- owns_lock()[link owns_lock.md]
- std::errc::device_or_resource_busy[link /reference/system_error/errc.md]
- std::generic_category()[link /reference/system_error/generic_category.md]
- std::system_error[link /reference/system_error/system_error.md]
- C++14
- Clang: 3.5 [mark verified]
- GCC: 4.9 [mark verified]
- ICC: ??
- Visual C++: 2015 [mark verified]