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

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

relent95 1月前

61 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)
  • 不,所以用了 +,但我可能可以更清楚一点。这仅适用于 Ruby MRI 1.9.x 和 2.0.0。我测试了所有安装版本的 OP 代码。MRI 1.9.3 和 2.0.0 的行为符合问题,但其他版本则不然。事实上,大多数主要的 Ruby 版本(可能与大多数正在使用的 Ruby 版本相反)的行为并不像 OP 所经历的那样。

返回
作者最近主题: