Tiga Cara: send
/ call
/ eval
- dan Tolok Ukurnya
Doa yang khas (untuk referensi):
s= "hi man"
s.length #=> 6
Menggunakan send
s.send(:length) #=> 6
Menggunakan call
method_object = s.method(:length)
p method_object.call #=> 6
Menggunakan eval
eval "s.length" #=> 6
Tolak ukur
require "benchmark"
test = "hi man"
m = test.method(:length)
n = 100000
Benchmark.bmbm {|x|
x.report("call") { n.times { m.call } }
x.report("send") { n.times { test.send(:length) } }
x.report("eval") { n.times { eval "test.length" } }
}
... seperti yang Anda lihat, instantiasi objek metode adalah cara dinamis tercepat dalam memanggil metode, juga perhatikan seberapa lambat menggunakan eval.
#######################################
##### The results
#######################################
#Rehearsal ----------------------------------------
#call 0.050000 0.020000 0.070000 ( 0.077915)
#send 0.080000 0.000000 0.080000 ( 0.086071)
#eval 0.360000 0.040000 0.400000 ( 0.405647)
#------------------------------- total: 0.550000sec
# user system total real
#call 0.050000 0.020000 0.070000 ( 0.072041)
#send 0.070000 0.000000 0.070000 ( 0.077674)
#eval 0.370000 0.020000 0.390000 ( 0.399442)
Penghargaan diberikan pada posting blog ini yang menjelaskan lebih banyak tentang tiga metode dan juga menunjukkan cara memeriksa apakah metode tersebut ada.