2015-12-16 05:07:31 +00:00
|
|
|
# frozen_string_literal: false
|
2008-04-09 03:12:03 +00:00
|
|
|
|
|
|
|
class LocalBarrier
|
|
|
|
def initialize(n)
|
2016-08-30 06:22:30 +00:00
|
|
|
@wait = Thread::Queue.new
|
|
|
|
@done = Thread::Queue.new
|
2008-04-09 03:12:03 +00: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 22:03:24 +00:00
|
|
|
sleep((rand(n) + 1) / 100.0)
|
2012-03-29 15:03:05 +00:00
|
|
|
print "#{i}: done\n"
|
2008-04-09 03:12:03 +00:00
|
|
|
lb.sync
|
2012-03-29 15:03:05 +00:00
|
|
|
print "#{i}: cont\n"
|
2008-04-09 03:12:03 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
lb.sync
|
2012-03-30 22:18:50 +00:00
|
|
|
print "#{n-1}: cont\n"
|
2012-04-03 04:27:30 +00:00
|
|
|
# lb.join # [ruby-dev:30653]
|
2008-04-09 03:12:03 +00:00
|
|
|
|
2012-03-29 15:03:05 +00:00
|
|
|
print "exit.\n"
|