std::shared_timed_mutex::try_lock_shared_for
template< class Rep, class Period > bool try_lock_shared_for( const std::chrono::duration<Rep,Period>& timeout_duration ); |
(C++14以上) | |
ミューテックスの共有モードでのロックを試みます。 指定された timeout_duration
が経過するか、共有ロックを取得するか、どちらかが先に発生するまでブロックします。 ロックの取得に成功した場合は true を返し、そうでなければ false を返します。
timeout_duration
が timeout_duration.zero()
より小さいまたは等しい場合、この関数は try_lock_shared() のように動作します。
スケジューリングやリソースの奪い合いによる遅延のため、この関数は timeout_duration
より長くブロックする可能性があります。
標準は時間計測に steady_clock を使用することを推奨しています。 処理系が代わりに system_clock を使用する場合、待機時間は時計調整の影響も受けるかもしれません。
try_lock_shared() と同様に、この関数は timeout_duration
の間のどこかの時点でミューテックスが他のいかなるスレッドにもロックされていなかったことがあっても、 spurious に失敗して false を返すことが認められています。
true を返した場合、同じミューテックスに対する以前の unlock() 操作は、この操作に対して同期します (std::memory_order を参照してください)。
いずれかのモード (共有または排他) でその mutex
をすでに所有しているスレッドによって try_lock_shared_for
が呼ばれた場合、動作は未定義です。
目次 |
[編集] 引数
timeout_duration | - | ブロックする最大時間 |
[編集] 戻り値
ロックの取得に成功した場合は true、そうでなければ false。
[編集] 例外
実行中に clock、time_point、または duration によって投げられるあらゆる例外 (標準ライブラリによって提供される clock、time_point、および duration は、例外を投げることはありません)。
[編集] 例
This section is incomplete Reason: no example |
[編集] 関連項目
共有所有権のためにミューテックスのロックを試みます。 利用可能でない場合はリターンします (パブリックメンバ関数) | |
共有所有権のためにミューテックスのロックを試みます。 指定された時刻に達するまでミューテックスが利用可能にならなければリターンします (パブリックメンバ関数) | |
ミューテックスのロックを試みます。 指定されたタイムアウト時間の間ミューテックスが利用可能にならなければリターンします (パブリックメンバ関数) |