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) -> object
deq(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