Três maneiras: send
/ call
/ eval
- e seus benchmarks
Chamada típica (para referência):
s= "hi man"
s.length #=> 6
Usando send
s.send(:length) #=> 6
Usando call
method_object = s.method(:length)
p method_object.call #=> 6
Usando eval
eval "s.length" #=> 6
Benchmarks
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" } }
}
... como você pode ver, instanciar um objeto de método é a maneira dinâmica mais rápida de chamar um método, observe também o quão lento é o uso de 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)
O crédito vai para este post do blog que detalha um pouco mais os três métodos e também mostra como verificar se os métodos existem.