希望这个截图能解释我的问题:
a = Thread.new { loop {} } b = Thread.new { loop {} } a.join
Ruby threads demo CPU usage http://img7.imageshack.us/img7/9858/rubycores.png
那么为什么我的两个核心都没有达到最大化?无论我使用多少线程,每次都是一样的;总cpu使用率似乎永远不会超过52%.
>ruby -v ruby 1.8.6 (2010-02-04 patchlevel 398) [i386-mingw32]
看起来你正在使用MRI,它无法并行运行线程.目前,唯一能够并行运行线程的生产就绪的Ruby实现是JRuby和IronRuby.
请记住,如果您希望线程实际并行运行,那么堆栈中的每个层都必须能够执行此操作.以JRuby为例:JRuby可以并行运行Ruby线程.但是,它通过将它们映射到JVM线程来实现线程,所以如果JVM无法并行运行线程(并且有一些情况就是这种情况),那么JRuby可以并行运行Ruby线程的事实不会帮助你一点.反过来,许多JVM将JVM线程映射到OS线程.再说一遍:如果操作系统无法并行运行线程,那么JVM就无法做到.最后但并非最不重要的是:如果只有一个处理器,那么整个练习无论如何都是毫无意义的.