類別 Thread::ConditionVariable

ConditionVariable 物件擴充了類別 Mutex。使用條件變數,可以在臨界區的過程中暫停,直到資源可用。

範例

mutex = Thread::Mutex.new
resource = Thread::ConditionVariable.new

a = Thread.new {
   mutex.synchronize {
     # Thread 'a' now needs the resource
     resource.wait(mutex)
     # 'a' can now have the resource
   }
}

b = Thread.new {
   mutex.synchronize {
     # Thread 'b' has finished using the resource
     resource.signal
   }
}

公開類別方法

new() 按一下切換來源

建立新的條件變數執行個體。

static VALUE
rb_condvar_initialize(VALUE self)
{
    struct rb_condvar *cv = condvar_ptr(self);
    ccan_list_head_init(&cv->waitq);
    return self;
}

公開執行個體方法

broadcast() 按一下切換來源

喚醒所有等待此鎖定的執行緒。

static VALUE
rb_condvar_broadcast(VALUE self)
{
    struct rb_condvar *cv = condvar_ptr(self);
    wakeup_all(&cv->waitq);
    return self;
}
signal() 按一下切換來源

喚醒等待此鎖定的第一個執行緒。

static VALUE
rb_condvar_signal(VALUE self)
{
    struct rb_condvar *cv = condvar_ptr(self);
    wakeup_one(&cv->waitq);
    return self;
}
wait(mutex, timeout=nil) 按一下切換來源

釋放 mutex 中持有的鎖定並等待;喚醒時重新取得鎖定。

如果提供 timeout,此方法會在經過 timeout 秒後傳回,即使沒有其他執行緒發出訊號。

傳回 mutex 中已中斷的結果。

static VALUE
rb_condvar_wait(int argc, VALUE *argv, VALUE self)
{
    rb_execution_context_t *ec = GET_EC();

    struct rb_condvar *cv = condvar_ptr(self);
    struct sleep_call args;

    rb_scan_args(argc, argv, "11", &args.mutex, &args.timeout);

    struct sync_waiter sync_waiter = {
        .self = args.mutex,
        .th = ec->thread_ptr,
        .fiber = nonblocking_fiber(ec->fiber_ptr)
    };

    ccan_list_add_tail(&cv->waitq, &sync_waiter.node);
    return rb_ensure(do_sleep, (VALUE)&args, delete_from_waitq, (VALUE)&sync_waiter);
}