9
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

rubyでカウンティングセマフォ

Posted at

探したがなかったのでつくった。

require 'monitor'

class CountingSemaphore
    def initialize(count)
        @count = count
        @monitor = Monitor.new
        @zero_cond = @monitor.new_cond
    end

    def synchronize
        @monitor.synchronize do
            @zero_cond.wait_while{ @count == 0 }
            @count -= 1
        end
        ret = yield
        @monitor.synchronize do
            @count += 1
            @zero_cond.broadcast
        end
        ret
    end
end

以下のように使う

cs = CountingSemaphore.new(10)

Array.new(100) do
    Thread.start do
        cs.synchronize{ `sleep 10` }
    end
end.each(&:join)

watch --interval=1 "ps auxw | grep sleep"(ubuntu)などとすれば最大10個であることが確認できる。

9
8
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?