るりまサーチ

最速Rubyリファレンスマニュアル検索!
46件ヒット [1-46件を表示] (0.167秒)
トップページ > 種類:インスタンスメソッド[x] > クエリ:r[x] > クエリ:end[x] > クラス:Thread::Queue[x]

別のキーワード

  1. _builtin to_r
  2. open3 pipeline_r
  3. matrix elements_to_r
  4. fileutils rm_r
  5. fileutils cp_r

ライブラリ

キーワード

検索結果

Thread::Queue#deq(non_block = false) -> object (3056.0)

キューからひとつ値を取り出します。キューが空の時、呼出元のスレッドは停止します。

...param non_block true を与えると、キューが空の時に例外 ThreadError が発生します。

//emlist[例][ruby]{
r
equire '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)...
...rue][ruby]{
r
equire '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)
}

begin
th1.join
q.pop(true)
r
escue => e
p e
end


# => resource1
# resource2
# resource3
# => #<ThreadError...

Thread::Queue#pop(non_block = false) -> object (3056.0)

キューからひとつ値を取り出します。キューが空の時、呼出元のスレッドは停止します。

...param non_block true を与えると、キューが空の時に例外 ThreadError が発生します。

//emlist[例][ruby]{
r
equire '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)...
...rue][ruby]{
r
equire '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)
}

begin
th1.join
q.pop(true)
r
escue => e
p e
end


# => resource1
# resource2
# resource3
# => #<ThreadError...

Thread::Queue#shift(non_block = false) -> object (3056.0)

キューからひとつ値を取り出します。キューが空の時、呼出元のスレッドは停止します。

...param non_block true を与えると、キューが空の時に例外 ThreadError が発生します。

//emlist[例][ruby]{
r
equire '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)...
...rue][ruby]{
r
equire '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)
}

begin
th1.join
q.pop(true)
r
escue => e
p e
end


# => resource1
# resource2
# resource3
# => #<ThreadError...

Thread::Queue#close -> self (3008.0)

キューを close します。close 済みのキューを再度 open することはできません。

...のように動作します。

* Thread::Queue#closed? は true を返します
* Thread::Queue#close は無視されます
* Thread::Queue#enq/push/<< は ClosedQueueError を発生します
* Thread::Queue#empty? が false を返す場合は Thread::Queue#deq/pop/shift は通常通りオブ...
...ジェクトを返します

また、ClosedQueueError は StopIteration を継承しているため、
close する事でループから脱出する事もできます。

例:

q = Queue.new
Thread.new{
while e = q.deq # wait for nil to break loop
# ...
end

}
q.close...