require 'thread' module SupplyDrop class ThreadPool def initialize(size) @size = size @jobs = Queue.new @retvals = [] @pool = Array.new(@size) do |i| Thread.new do Thread.current[:id] = i catch(:exit) do loop do job, args = @jobs.pop @retvals << job.call(*args) end end end end end def schedule(*args, &block) @jobs << [block, args] end def shutdown @size.times do schedule { throw :exit } end @pool.map(&:join) @retvals end end end