Изменения документа Expression tree | Деревья выражений

Редактировал(а) Alexandr Fokin 2024/02/10 14:04

<
От версии < 8.13 >
отредактировано Alexandr Fokin
на 2023/11/19 14:33
К версии < 6.5 >
отредактировано Alexandr Fokin
на 2020/02/16 21:35
>
Изменить комментарий: Updated parent field.

Комментарий

Подробности

Свойства страницы
Название
... ... @@ -1,1 +1,1 @@
1 -Expression tree | Деревья выражений
1 +Expression tree
Родительский документ
... ... @@ -1,1 +1,1 @@
1 -Разработка.NET.C#.Рантайм и типы.WebHome
1 +xwiki:Разработка.NET.C#.WebHome
Содержимое
... ... @@ -1,60 +6,12 @@
1 -|(% style="width:179px" %) |(% style="width:1306px" %)Деревья выражений, ExpressionTree, Expression Tree, ExpressionTrees, Expression Trees
2 -|(% style="width:179px" %)**ExpressionTree**|(% style="width:1306px" %)(((
3 -Позволяет накапливать выражения, содержащие операторы языка c#, в виде древовидной структуры. А после этого скомпилировать эту структуру в делегат.
4 -(Или обрабатывать, как делает [[EntityFramework | EntityFrameworkCore>>doc:Разработка.NET.Работа с БД.EntityFramework | EntityFrameworkCore.WebHome]] для трансляции запросов).
5 -При этом формировать и компилировать деревья выражений можно в рантайме.
6 6  
7 -Замечание: вызов делегата, созданного на основе дерева выражений, быстрее, чем вызов метода напрямую через [[Reflection | Рефлексия >>doc:Разработка.NET.C#.Рантайм и типы.Reflection | Рефлексия .WebHome]].
8 -)))
9 -|(% style="width:179px" %)**Может использоваться для:**|(% style="width:1306px" %)(((
10 -* Динамическое создание поведения.
11 -* Динамическое создание фабрики для объекта (в том числе Generic версии).
12 -* Ускорении повторяющихся операций, использующих рефлексию.
13 -
14 -* Создания Generic типа с возможностью выполнять математические операции над элементами T.
15 -Например матрица <int> или <double>, в которой будет логика складывающая значения ячеек
16 -* Выполнения маппинга свойств (Как более быстрый аналог [[Рефлексия | Reflection>>Разработка.NET.C#.Рантайм и типы.Reflection | Рефлексия .WebHome]])
17 -* [[IQurable>>doc:Разработка.NET.C#.Коллекции.IQurable.WebHome]] провайдер, формирующий запрос во внешнее хранилище (EntityFramework SQL)
18 -)))
19 -|(% style="width:179px" %)**Ссылки:**|(% style="width:1306px" %)(((
20 -[[GoF Design Patterns | Паттерны Interpreter, Visitor>>doc:Архитектура и модели.Паттерны проектирования.GoF Design Patterns.WebHome||style="outline-width: 0px !important; user-select: auto !important;"]]
21 -
22 -Введение в Expressions в языке C#
23 23  http://sonyks2007.blogspot.com/2014/07/expressions-c.html
24 -
25 -Expression Tree. Просто о сложном
26 26  http://sonyks2007.blogspot.com/2014/08/expression-tree.html
27 -
28 -Expressions в C# — impress yourself!
29 29  https://habr.com/ru/post/83169/
5 +https://habr.com/ru/post/256821/
30 30  
31 -Деревья выражений в C# на примере нахождения производной (Expression Tree Visitor vs Pattern matching)
32 -https://habr.com/ru/post/486972/
33 33  
34 -DotNet | Максим Аршинов — Деревья выражений в enterprise-разработке ([[IQurable>>doc:Разработка.NET.C#.Коллекции.IQurable.WebHome]], [[JavaScript>>doc:Разработка.Frontend.JavaScript.WebHome]], [[Reflection | Рефлексия, >>doc:Разработка.NET.C#.Рантайм и типы.Reflection | Рефлексия .WebHome]][[Moq>>doc:Разработка.NET.Библиотеки.Тестирование.Moq.WebHome]])
35 -[[https:~~/~~/www.youtube.com/watch?v=J2XzsCoJM4o>>https://www.youtube.com/watch?v=J2XzsCoJM4o]]
36 -)))
37 37  
38 -----
39 -
40 -==== Внутренние ссылки: ====
41 -
42 -====== Дочерние страницы: ======
43 -
44 -{{children/}}
45 -
46 -====== Обратные ссылки: ======
47 -
48 -{{velocity}}
49 -#set ($links = $doc.getBacklinks())
50 -#if ($links.size() > 0)
51 - #foreach ($docname in $links)
52 - #set ($rdoc = $xwiki.getDocument($docname).getTranslatedDocument())
53 - * [[$escapetool.xml($rdoc.fullName)]]
54 - #end
55 -#else
56 - No back links for this page!
57 -#end
58 -{{/velocity}}
59 -
60 -----
9 +Может использоваться для
10 +создания Generic типа с возможностью выполнять математические операции над элементами T. Например матрица <int> или <double>, в которой будет логика складывающая значения ячеек
11 +выполнения маппинга свойств (более быстрый аналог рефлексии)
12 +iqueryable