Недопонимание скомпилированных деревьев выражений?
У меня есть это выражение:
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()
Что это компилирует? И в чем разница между первым и последующим исполнением ...?
Компиляция должна быть то, что происходит один раз, а не повторяется позже ....
Что / Как это помогает мне?