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