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

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

relent95 1月前

67 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 1.9.3 上运行此代码,我可以获得竞争条件,但在 Ruby 2.4.1 上运行则不会。如果我使用 JRuby 9.13(而且奇怪的是,它比任何版本都慢),即使是简单的单一赋值也会变得不确定。所以我学到的教训是,如果你要使用线程做任何事情并关心预期的行为和性能,你最好真正了解你的 Ruby 版本以及它如何处理线程。

返回
作者最近主题: