class MonitorMixin::ConditionVariable

[edit]

要約

MonitorMixinMonitor のための条件変数クラスです。 MonitorMixin#new_cond が返します。ユーザが MonitorMixin::ConditionVariable.new を直接呼ぶことはありません。

目次

インスタンスメソッド

インスタンスメソッド

broadcast -> ()[permalink][rdoc][edit]

その条件変数で待っている全てのスレッドの実行を再開します。

[SEE_ALSO] MonitorMixin::ConditionVariable#signal

signal -> ()[permalink][rdoc][edit]

その条件変数で待っているスレッドがあれば実行を再開させます。

複数のスレッドが待っている場合には1つのスレッドのみ実行を再開します。

[SEE_ALSO] MonitorMixin::ConditionVariable#broadcast

wait(timeout = nil) -> bool[permalink][rdoc][edit]

モニタのロックを開放し、現在のスレッドを停止します。

これを呼ぶスレッドはモニタのロックを保持している必要があります。

MonitorMixin::ConditionVariable#signalMonitorMixin::ConditionVariable#broadcast で起こされるまでスレッドは停止し続けます。

timeout を与えた場合は最大 timeout 秒まで停止した後にスレッドを再開します。

実行を再開したスレッドはモニタのロックを保持した状態になります。これによって危険領域(critical section)上で動作しているスレッドはただ一つになり、排他を実現します。

true を返します。timeout が与えられていて待ち時間が timeout を越えた場合は false を返します。

[PARAM] timeout:
タイムアウトまでの秒数。指定しなかった場合はタイムアウトしません。
[EXCEPTION] ThreadError:
ロックを持っていないスレッドがこのメソッドを呼びだした場合に発生します

[SEE_ALSO] MonitorMixin::ConditionVariable#wait_while, MonitorMixin::ConditionVariable#wait_until

wait_until { ... } -> ()[permalink][rdoc][edit]

モニタのロックを開放し、現在のスレッドをブロックで指定した条件を満たすまで停止します。

MonitorMixin::ConditionVariable#signalMonitorMixin::ConditionVariable#broadcast でスレッドが起こされると、ロックを取得し、ブロックを評価しその結果によってこのメソッドから抜け処理を継続するか再びロックを開放しスレッドを停止するかを決めます。

[SEE_ALSO] MonitorMixin::ConditionVariable#wait

wait_while { ... } -> ()[permalink][rdoc][edit]

モニタのロックを開放し、現在のスレッドをブロックで指定した条件を満たしている間停止します。

MonitorMixin::ConditionVariable#signalMonitorMixin::ConditionVariable#broadcast でスレッドが起こされると、ロックを取得し、ブロックを評価しその結果によってこのメソッドから抜け処理を継続するか再びロックを開放しスレッドを停止するかを決めます。

[EXCEPTION] ThreadError:
ロックを持っていないスレッドがこのメソッドを呼びだした場合に発生します

[SEE_ALSO] MonitorMixin::ConditionVariable#wait