Недопонимание скомпилированных деревьев выражений?

У меня есть это выражение:

Expression<Func<string, bool>> f = s => s.Length < 5;

ParameterExpression p = Expression.Parameter (typeof (string), "s");
MemberExpression stringLength = Expression.Property (p, "Length");
ConstantExpression five = Expression.Constant (5);
BinaryExpression comparison = Expression.LessThan (stringLength, five);
Expression<Func<string, bool>> lambda= Expression.Lambda<Func<string, bool>> (comparison, p);

// позволяет: тест

Func<string, bool> runnable = lambda.Compile();
Conso,le.WriteLine (runnable ("kangaroo")); // False
Console.WriteLine (runnable ("dog")); //True

Я хочу спросить о.Compile()

Что это компилирует? И в чем разница между первым и последующим исполнением ...?

Компиляция должна быть то, что происходит один раз, а не повторяется позже ....

Что / Как это помогает мне?

Ответы на вопрос(3)

Ваш ответ на вопрос