class SimpleExpTree { static void Main {
// Представить лямбда-выражение в виде данных.
Expression
IsFactorExp = (n, d) => (d != 0) ? (n % d) ==0 : false;
// Скомпилировать данные выражения в исполняемый код.
Func
// Выполнить выражение, if(IsFactor(10, 5))
Console.WriteLine("Число 5 является множителем 10.");
if(!IsFactor(10, 7))
Console.WriteLine("Число 7 не является множителем 10.");
Console.WriteLine ;
}
}
Вот к какому результату приводит выполнение этой программы.
Число 5 является множителем 10.
Число 7 не является множителем 10.
Данный пример программы наглядно показывает два основных этапа применения дерева выражений. Сначала в ней создается дерево выражений с помощью следующего оператора.
Expression
IsFactorExp = (n, d) => (d != 0) ? (n % d) ==0 : false;
В этом операторе конструируется представление лямбда-выражения в оперативной памяти. Как пояснялось выше, это представление доступно по ссылке, присваиваемой делегатуIsFactorExp.А в следующем операторе данные выражения преобразуются в исполняемый код.
Func
После выполнения этого оператора делегатIsFactorExpможет быть вызван, чтобы определить, является ли одно целое число множителем другого.
Обратите также внимание на то, что
Методы расширения
Как упоминалось выше, методы расширения предоставляют средства для расширения функций класса, не прибегая к обычному механизму наследования. Методы расширения создаются нечасто, поскольку механизм наследования, как правило, предлагает лучшее решение. Тем не менее знать, как они действуют, никогда не помешает. Ведь они имеют существенное значение для LINQ.