aliases: Queue
Queue はスレッド間の FIFO(first in first out) の通信路です。スレッドが空のキューを読み出そうとすると停止します。キューになんらかの情報が書き込まれると実行は再開されます。
最大サイズが指定できる Queue のサブクラス Thread::SizedQueue も提供されています。
require 'thread'
q = Queue.new
th1 = Thread.start do
  while resource = q.pop
    puts resource
  end
end
[:resource1, :resource2, :resource3, nil].each{|r|
  q.push(r)
}
th1.join
実行すると以下のように出力します。
$ ruby que.rb resource1 resource2 resource3
new -> Thread::Queue[permalink][rdoc]新しいキューオブジェクトを生成します。
push(value) -> ()[permalink][rdoc]self << value -> ()enq(value) -> ()キューの値を追加します。待っているスレッドがいれば実行を再開させます。返り値は不定です。
clear -> ()[permalink][rdoc]キューを空にします。返り値は不定です。
例
q = Queue.new
[:resource1, :resource2, :resource3, nil].each { |r| q.push(r) }
q.length # => 4
q.clear
q.length # => 0
close -> self[permalink][rdoc]キューを close します。close 済みのキューを再度 open することはできません。
close 後は以下のように動作します。
また、ClosedQueueError は StopIteration を継承しているため、 close する事でループから脱出する事もできます。
例:
q = Queue.new
Thread.new{
  while e = q.deq # wait for nil to break loop
    # ...
  end
}
q.close
closed? -> bool[permalink][rdoc]キューが close されている時に true を返します。
例
q = Queue.new
[:resource1, :resource2, :resource3, nil].each { |r| q.push(r) }
q.closed? # => false
q.close
q.closed? # => true
pop(non_block = false) -> object[permalink][rdoc]shift(non_block = false) -> objectdeq(non_block = false) -> objectキューからひとつ値を取り出します。キューが空の時、呼出元のスレッドは停止します。
empty? -> bool[permalink][rdoc]キューが空の時、真を返します。
例
q = Queue.new
q.empty? # => true
q.push(:resource)
q.empty? # => false
length -> Integer[permalink][rdoc]size -> Integerキューの長さを返します。
例
q = Queue.new
[:resource1, :resource2, :resource3, nil].each { |r| q.push(r) }
q.length # => 4
num_waiting -> Integer[permalink][rdoc]キューを待っているスレッドの数を返します。
例
require 'thread'
q = SizedQueue.new(1)
q.push(1)
t = Thread.new { q.push(2) }
sleep 0.05 until t.stop?
q.num_waiting # => 1
q.pop
t.join