queue.pop上的死锁 - Ruby

时间:2012-07-25 23:34:18

标签: ruby

这会导致:检测到死锁(致命)错误

require 'thread'

@queue = Queue.new
x = @queue.pop

为什么这不起作用?

1 个答案:

答案 0 :(得分:1)

来自Ruby documentation for Queue#pop

  

从队列中检索数据。如果队列为空,则挂起调用线程,直到将数据推送到队列。如果non_block为true,则不会挂起该线程,并引发异常。

您正在使用单个线程,因此您的队列永远不会包含任何对象,因此您的线程将永久挂起(死锁)。

试试这个

require "thread"

queue = Queue.new
thread1 = Thread.new do
  5.times do |i|
    x = queue.pop
    sleep rand(i) # simulate workload
    puts "taken #{x} from queue!"
  end
end

thread2 = Thread.new do
  5.times do |i|
    sleep rand(i) # simulate workload
    queue.push i
    puts "pushed #{i} to the queue!"
  end
end

thread1.join

您现在有两个线程,因此您不会遇到死锁。当队列为空时,消费者线程将被挂起,但当第二个线程将某些东西推送到队列时,它将再次变为活动状态。