Изменения документа Асинхронность. Async Await

Редактировал(а) Alexandr Fokin 2025/04/09 12:46

<
От версии < 3.9 >
отредактировано Alexandr Fokin
на 2022/12/15 10:58
К версии < 6.8
отредактировано Alexandr Fokin
на 2025/04/09 12:46
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Родительский документ
... ... @@ -1,1 +1,1 @@
1 -Разработка.NET.C#.Многопоточность.WebHome
1 +Разработка.NET.C#.Многопоточность и асинхронность.WebHome
Содержимое
... ... @@ -1,66 +1,49 @@
1 -=== Подходы к реализации асинхронного кода. ===
2 -
1 +|(% style="width:177px" %)Подходы к реализации асинхронного кода.|(% style="width:1308px" %)(((
3 3  На протяжении истории существовало несколько подходов к реализации асинхронного кода. Подход на основе async-await является наиболее молодым.
4 4  Зачастую асинхронность связана с операциями ввода/вывода (Файловая система, Базы данных, Http запросы, операция ожидания (Task.Delay) и другое), где присутствует сравнительно большое ожидание в котором поток не задействован.
5 5  
6 -(% style="width:669px" %)
7 -|(% style="width:267px" %) |(% style="width:404px" %)
8 -|(% style="width:267px" %)(((
9 -APM
10 -)))|(% style="width:404px" %)Begin
11 -End
12 -|(% style="width:267px" %)(((
13 -Event-based Asynchronous
14 -)))|(% style="width:404px" %)(((
15 -Callback
16 -Event
17 -)))
18 -|(% style="width:267px" %)TAP (Task-based asynchronous)|(% style="width:404px" %)(((
19 -Task
20 -Async Await
21 -[[SynchronizationContext | Контекст синхронизации>>Разработка.NET.C#.Многопоточность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]]
22 -)))
23 -
24 24  Шаблоны асинхронного программирования
25 25  [[https:~~/~~/docs.microsoft.com/ru-ru/dotnet/standard/asynchronous-programming-patterns/>>https://docs.microsoft.com/ru-ru/dotnet/standard/asynchronous-programming-patterns/]]
26 26  
27 -----
28 -
29 -=== TAP | Async/Await ===
30 -
8 +|(% style="width:233px" %)(((
9 +APM
10 +)))|(% style="width:1052px" %)Begin - End
11 +Блокирующий подход.
12 +|(% style="width:233px" %)Event-based Asynchronous|(% style="width:1052px" %)Callback, event.
13 +Callback:
14 +Неблокирующий подход, но код менее удобный и менее читаемый.
15 +И если рассмотреть обработку запроса, то в конце обработки все равно нужно будет синхронно (блокирующе) дождаться всех асинхронных задач.
16 +|(% style="width:233px" %)TAP (Task-based asynchronous)|(% style="width:1052px" %)Task (Promise/Feature)
17 +Async Await
18 +[[SynchronizationContext ~~| Контекст синхронизации>>Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]].
19 +Неблокирующий подход, при этом код пишется в синхронном (последовательном) виде.
20 +|(% style="width:233px" %)Green threads|(% style="width:1052px" %)Подход к механизму, когда на уровне кода не используется никаких дополнительных пометок о асинхронном исполнении, а ответственность за выявление асинхронных блоков и их обработка (асинхронное неблокирующее ожидание) лежит на среде выполнения приложения.
21 +Можно сказать, что формат кода приближен к шаблону TAP, но не требуется указывать в коде async методы и await - места ожидания.
22 +)))
23 +|(% style="width:177px" %)Подробнее о
24 +TAP ~| Async/Await|(% style="width:1308px" %)(((
31 31  Более мягкий подход к асинхронности.
32 -Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения задач, выполняющий поток не простаивает, а освобождается и может выполнять другие задачи.
26 +Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения асинхронного кода, выполняющий поток не блокируется, а освобождается и может выполнять другие задачи.
33 33  
34 -|(% style="width:79px" %) |(% style="width:1443px" %)
35 -|(% style="width:79px" %)Desktop|(% style="width:1443px" %)Позволяет не блокировать UI (зависание основного потока во время выполнения долгих операций).
36 -Когда встречается реальная асинхронная операция UI Thread освобождается и идет обрабатывать другие события графического интерфейса. После того, как асинхронная операция будет завершена, код идущей за ней может продолжить выполнение в UI Thread.
28 +
29 +|(% style="width:79px" %)Desktop (GUI)|(% style="width:1443px" %)Позволяет не блокировать UI (зависание основного потока во время выполнения долгих операций [[Event loop>>doc:Архитектура и модели.Модели.Event loop.WebHome]]).
30 +Когда встречается реальная асинхронная операция UI Thread освобождается и идет обрабатывать другие события графического интерфейса. После того, как асинхронная операция будет завершена, код идущей за ней может продолжить выполнение в UI Thread (или в другом потоке из пула).
37 37  |(% style="width:79px" %)Web|(% style="width:1443px" %)(((
38 -Позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение).
32 +Позволяет обрабатывать большее кол-во параллельных задач (запросов) меньшим кол-во потоков.
33 +(Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается (возвращается в пул) и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток из пула продолжит выполнение).
39 39  
40 40  Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций.
41 41  При этом присутствуют небольшие накладные расходы, связанные с работой Async/Await.
42 -)))
43 43  
44 -----
45 -
46 -[[SynchronizationContext | Контекст синхронизации>>Разработка.NET.C#.Многопоточность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]]
47 -
48 -----
49 -
50 -==== Taskcompletionsource ====
51 -
52 -Taskcompletionsource - инструмент позволяющий преобразовать некоторые другие виды асинхронного кода к формату паттерну TAP.
53 -
54 -Материалы:
55 -
56 -* В чем смысл TaskCompletionSource<T> и когда его лучше использовать?
57 -[[https:~~/~~/ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать>>https://ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать]]
58 -
59 -----
60 -
61 -=== Материалы: ===
62 -
38 +Позволяет пулу потоков обходиться меньшим количеством потоков за счет отсутствия (бесполезной) блокировки потока на ожидании завершения асинхронной операции.
39 +)))
40 +)))
41 +|(% style="width:177px" %)Материалы:|(% style="width:1308px" %)(((
42 +|(% style="width:106px" %)Книги|(% style="width:1184px" %)(((
63 63  * [[Асинхронное программирование в C# 5.0 | O’Reilly>>doc:Книги.O’Reilly.Асинхронное программирование в C# 5\.0 | O’Reilly.WebHome]]
44 +* [[CLR via C# | Джеффри Рихтер>>doc:Книги.CLR via C# | Джеффри Рихтер.WebHome]]
45 +)))
46 +|(% style="width:106px" %)Статьи|(% style="width:1184px" %)(((
64 64  * Async/await в C#: концепция, внутреннее устройство, полезные приемы
65 65  [[https:~~/~~/habr.com/ru/post/470830/>>https://habr.com/ru/post/470830/||style="background-color: rgb(255, 255, 255);"]]
66 66  * Асинхронные методы, async и await
... ... @@ -69,15 +69,37 @@
69 69  [[https:~~/~~/habr.com/ru/company/dododev/blog/435666/>>https://habr.com/ru/company/dododev/blog/435666/]]
70 70  * Async/await в C#: подводные камни
71 71  [[https:~~/~~/habr.com/ru/post/257221/>>https://habr.com/ru/post/257221/]]
72 -* (((
73 -Async/await и механизм реализации в C# 5.0
55 +* Async/await и механизм реализации в C# 5.0
74 74  [[https:~~/~~/habr.com/ru/post/260217/>>https://habr.com/ru/post/260217/]]
75 -)))
76 -* (((
77 -Async/await in C#: pitfalls
57 +* Async/await in C#: pitfalls
78 78  https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/
79 -)))
80 -* (((
81 -Асинхронность в C#. Разрушение легенд
59 +* Асинхронность в C#. Разрушение легенд
82 82  https://techrocks.ru/2020/01/11/asynchrony-in-c-sharp/
61 +* RadioDotNet. Async practices, breaking changes, time provider
62 +[[https:~~/~~/www.youtube.com/watch?v=f4-gb-cg_MQ&list=PLbxr_aGL4q3SpQ9GRn2jv-NEpvN23CUC5>>https://www.youtube.com/watch?v=f4-gb-cg_MQ&list=PLbxr_aGL4q3SpQ9GRn2jv-NEpvN23CUC5]]
83 83  )))
64 +)))
65 +
66 +----
67 +
68 +==== Внутренние ссылки: ====
69 +
70 +====== Дочерние страницы: ======
71 +
72 +{{children/}}
73 +
74 +====== Обратные ссылки: ======
75 +
76 +{{velocity}}
77 +#set ($links = $doc.getBacklinks())
78 +#if ($links.size() > 0)
79 + #foreach ($docname in $links)
80 + #set ($rdoc = $xwiki.getDocument($docname).getTranslatedDocument())
81 + * [[$escapetool.xml($rdoc.fullName)]]
82 + #end
83 +#else
84 + No back links for this page!
85 +#end
86 +{{/velocity}}
87 +
88 +