ruby - 作为开发人员,不同的 Ruby 线程模型(Ruby 与 JRuby)对您的代码有什么实际影响?

标签 ruby multithreading jruby

我试图了解 MRI Ruby 1.8 和 JRuby 之间不同线程模型的实际影响。

作为开发者,这种差异对我意味着什么?

另外,MRI Ruby 1.8 中是否有任何实际代码示例会由于不同的线程模型而在 JRuby 上具有更差的性能特征?

最佳答案

状态

  • ruby 1.8 有绿色线程,这些线程可以快速创建/删除(作为对象)但不是真正的并行执行,甚至不由操作系统调度,而是由虚拟机调度
  • ruby 1.9 有真正的线程,由于操作系统调用,创建/删除(作为对象)很慢,但由于 GIL(全局解释器锁)一次只允许一个线程执行,所以这些都不是真正的线程并行
  • JRuby 也有操作系统调度的真实线程,并且是真正并发的

结论

在 2 核 CPU 上运行的线程程序在 JRuby 上运行速度比其他实现更快,关于线程的观点

注意!

许多现有的 ruby​​ 库都不是线程安全的,因此 JRuby 的优势在很多时候都没有用。
另请注意,如果要使用线程,许多 ruby​​ 编程技术(例如类变量)将需要额外的编程工作来确保线程安全(互斥锁、监视器等)。

关于ruby - 作为开发人员,不同的 Ruby 线程模型(Ruby 与 JRuby)对您的代码有什么实际影响?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/999482/

相关文章:

ruby-on-rails - 我可以在 ActiveRecord 中序列化什么对象?

java - 在 Spring 4 中运行并行线程的优雅方式

multithreading - 将 gprof 与 pthread 结合使用

ruby - Ruby:我可以完全透明地将一个类包装到另一个类中吗?

mysql - Jruby Activerecord 给了我过时的连接

ios - 如何通过Ruby(或Xcodeproj)获取目标版本

ruby-on-rails - Ruby 救援和最佳实践语法

ruby - 合并哈希数组中的重复项

multithreading - 使用并行流时,Spock 单元测试卡住

java - 如何在jruby或java中模拟File::Stat.ino?