JRuby性能探索:JIT编译器与写时复制机制
1. 监测JRuby的即时编译器
JRuby能够通过即时(JIT)编译器加速Ruby代码。它会将Ruby程序转换为Java字节码指令,再由JVM编译成计算机微处理器可直接执行的机器语言。下面通过实验来观察这一过程,并测量其对代码速度的提升效果。
1.1 实验代码
以下是一个打印1到100之间10个随机数的Ruby程序:
array = (1..100).to_a
10.times do
sample = array.sample
puts sample
end
运行该代码会输出10个随机数。为了便于实验,移除 puts 语句并增加迭代次数:
array = (1..100).to_a
1000.times do
sample = array.sample
end
1.2 使用 -J-XX:+PrintCompilation 选项
运行上述程序不会有输出,因为移除了 puts 语句。现在使用调试标志 -J-XX:+PrintCompilation 来查看JVM的JIT编译器的工作情况:
$ jruby -J-XX:+PrintCompilation jit.rb
1
超级会员免费看
订阅专栏 解锁全文
54

被折叠的 条评论
为什么被折叠?



