¿Por qué es == más rápido que eql?

Leí en la documentación de la clase String queeql? es un operador de igualdad estricto, sin conversión de tipos, y== es un operador de igualdad que intenta convertir el segundo argumento en una cadena, y el código fuente de C para estos métodos confirma que

loseql? código fuente:

<code>static VALUE
rb_str_eql(VALUE str1, VALUE str2)
{
    if (str1 == str2) return Qtrue;
    if (TYPE(str2) != T_STRING) return Qfalse;
    return str_eql(str1, str2);
}
</code>

los== código fuente:

<code>VALUE
rb_str_equal(VALUE str1, VALUE str2)
{
    if (str1 == str2) return Qtrue;
    if (TYPE(str2) != T_STRING) {
        if (!rb_respond_to(str2, rb_intern("to_str"))) {
            return Qfalse;
        }
        return rb_equal(str2, str1);
    }
    return str_eql(str1, str2);
}
</code>

Pero cuando intenté comparar estos métodos, me sorprendió que== es más rápido queeql? ¡Hasta un 20%! Mi código de referencia es:

<code>require "benchmark"

RUN_COUNT = 100000000
first_string = "Woooooha"
second_string = "Woooooha"

time = Benchmark.measure do
  RUN_COUNT.times do |i|
    first_string.eql?(second_string)
  end
end
puts time

time = Benchmark.measure do
  RUN_COUNT.times do |i|
    first_string == second_string
  end
end
puts time
</code>

Y resultados:

Ruby 1.9.3-p125:

<code>26.420000   0.250000  26.670000 ( 26.820762)
21.520000   0.200000  21.720000 ( 21.843723)
</code>

Ruby 1.9.2-p290:

<code>25.930000   0.280000  26.210000 ( 26.318998)
19.800000   0.130000  19.930000 ( 19.991929)
</code>

Entonces, ¿alguien puede explicar por qué el más simpleeql? el método es más lento que== ¿Método en el caso cuando lo ejecuto para dos cadenas similares?

Respuestas a la pregunta(3)

Su respuesta a la pregunta