2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2008-04-08 23:12:03 -04:00
|
|
|
require 'thread'
|
|
|
|
|
|
|
|
class LocalBarrier
|
|
|
|
def initialize(n)
|
2016-08-30 02:22:30 -04:00
|
|
|
@wait = Thread::Queue.new
|
|
|
|
@done = Thread::Queue.new
|
2008-04-08 23:12:03 -04:00
|
|
|
@keeper = begin_keeper(n)
|
|
|
|
end
|
|
|
|
|
|
|
|
def sync
|
|
|
|
@done.push(true)
|
|
|
|
@wait.pop
|
|
|
|
end
|
|
|
|
|
|
|
|
def join
|
|
|
|
@keeper.join
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
def begin_keeper(n)
|
|
|
|
Thread.start do
|
|
|
|
n.times do
|
|
|
|
@done.pop
|
|
|
|
end
|
|
|
|
n.times do
|
|
|
|
@wait.push(true)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
n = 10
|
|
|
|
|
|
|
|
lb = LocalBarrier.new(n)
|
|
|
|
|
|
|
|
(n - 1).times do |i|
|
|
|
|
Thread.start do
|
2013-12-14 17:03:24 -05:00
|
|
|
sleep((rand(n) + 1) / 100.0)
|
2012-03-29 11:03:05 -04:00
|
|
|
print "#{i}: done\n"
|
2008-04-08 23:12:03 -04:00
|
|
|
lb.sync
|
2012-03-29 11:03:05 -04:00
|
|
|
print "#{i}: cont\n"
|
2008-04-08 23:12:03 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
lb.sync
|
2012-03-30 18:18:50 -04:00
|
|
|
print "#{n-1}: cont\n"
|
2012-04-03 00:27:30 -04:00
|
|
|
# lb.join # [ruby-dev:30653]
|
2008-04-08 23:12:03 -04:00
|
|
|
|
2012-03-29 11:03:05 -04:00
|
|
|
print "exit.\n"
|