8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

为什么 Ruby 中不存在竞争条件

relent95 1月前

69 0

我正在试验多线程示例。我尝试使用以下代码产生竞争条件。但我总是得到相同的(正确的)输出。类 Counter attr_reader:...

我正在试验多线程示例。我尝试使用以下代码产生竞争条件。但我总是得到相同(正确)的输出。

class Counter
  attr_reader :count
  def initialize
    @count = 0
  end
  def increment
    @count += 1
  end
  def decrement
    @count -= 1
  end
end
c = Counter.new
t1 = Thread.start { 100_0000.times { c.increment } }
t2 = Thread.start { 100_0000.times { c.increment } }
t1.join
t2.join
p c.count #200_0000

我能够使用每个线程中更少的迭代次数来观察 Java 中的竞争条件。是不是因为我运行的次数不够多而导致竞争条件产生,还是 + / - 中的线程是安全的?我使用的是 ruby​​ 2.0.0p247

帖子版权声明 1、本帖标题:为什么 Ruby 中不存在竞争条件
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由relent95在本站《ruby》版块原创发布, 转载请注明出处!
最新回复 (0)
  • JRuby (9.1.13) 怎么样?我以为它应该提供真正的线程 (而不是使用 GIL),但我得到的结果与 MRI 2.4.1 相同 (即,除非我按照下面的答案模拟竞争,否则计数一致)。

返回
作者最近主题: