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

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

<
От версии < 3.1 >
отредактировано Alexandr Fokin
на 2020/08/17 12:15
К версии < 3.8 >
отредактировано Alexandr Fokin
на 2022/12/15 10:57
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Название
... ... @@ -1,1 +1,1 @@
1 -Async Await
1 +Асинхронность. Async Await
Содержимое
... ... @@ -1,29 +1,83 @@
1 -**Async/Await**
1 +=== Подходы к реализации асинхронного кода. ===
2 2  
3 -Понятие конктеста выполнения.
3 +На протяжении истории существовало несколько подходов к реализации асинхронного кода. Подход на основе async-await является наиболее молодым.
4 +Зачастую асинхронность связана с операциями ввода/вывода (Файловая система, Базы данных, Http запросы, операция ожидания (Task.Delay) и другое), где присутствует сравнительно большое ожидание в котором поток не задействован.
4 4  
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 +Шаблоны асинхронного программирования
25 +[[https:~~/~~/docs.microsoft.com/ru-ru/dotnet/standard/asynchronous-programming-patterns/>>https://docs.microsoft.com/ru-ru/dotnet/standard/asynchronous-programming-patterns/]]
26 +
27 +----
28 +
29 +=== TAP | Async/Await ===
30 +
5 5  Более мягкий подход к асинхронности.
6 6  Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения задач, выполняющий поток не простаивает, а освобождается и может выполнять другие задачи.
7 -В случае desctop приложения это позволяет не блокировать UI (зависание основного потока во время выполнения операций).
8 -В случае web приложений, данный подход позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение) Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций. При этом присутсвуют небольшие накладные расходы, связанные с работой Async/Await.
9 9  
10 -DeadLock при async await. Возможен в ситуациях, когда есть контекст синхронизации (UI контекст основного ui потока, ASP контекст запроса)
11 -ConfigureAwait - указывает на то, должны ли операции продожаться в том же контексте после завершения await (или же они могуть быть выполнены в любом контексте)
12 -[[devblogs.microsoft| ConfigureAwait FAQ>>https://devblogs.microsoft.com/dotnet/configureawait-faq/?utm_source=csharp&utm_medium=email&utm_campaign=digest]]
34 +|(% style="width:79px" %) |(% style="width:1443px" %)
35 +|(% style="width:79px" %)Desktop|(% style="width:1443px" %)Позволяет не блокировать UI (зависание основного потока во время выполнения долгих операций).
36 +Когда встречается реальная асинхронная операция UI Thread освобождается и идет обрабатывать другие события графического интерфейса. После того, как асинхронная операция будет завершена, код идущей за ней может продолжить выполнение в UI Thread.
37 +|(% style="width:79px" %)Web|(% style="width:1443px" %)(((
38 +Позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение).
13 13  
40 +Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций.
41 +При этом присутствуют небольшие накладные расходы, связанные с работой Async/Await.
42 +)))
14 14  
44 +----
45 +
46 +[[SynchronizationContext | Контекст синхронизации>>Разработка.NET.C#.Многопоточность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]]
47 +
48 +----
49 +
50 +==== Taskcompletionsource ====
51 +
52 +Taskcompletionsource - инструмент позволяющий преобразовать некоторые другие виды асинхронного кода к формату паттерну TAP.
53 +
15 15  Материалы:
16 -* [[Habr Async/await в C#: концепция, внутреннее устройство, полезные приемы>>https://habr.com/ru/post/470830/]]
17 -* [[Metanit Aсинхронное программирование>>https://metanit.com/sharp/tutorial/13.3.php]]
18 -* [[Habr Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET>>https://habr.com/ru/company/dodopizzadev/blog/435666/]]
19 -* [[Habr Async/await в C#: подводные камни>>https://habr.com/ru/post/257221/]]
20 -* [[Habr Async/await и механизм реализации в C# 5.0>>https://habr.com/ru/post/260217/]]
21 21  
56 +* В чем смысл TaskCompletionSource<T> и когда его лучше использовать?
57 +[[https:~~/~~/ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать>>https://ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать]]
22 22  
23 -ConfigureAwait, кто виноват и что делать?
24 -https://habr.com/ru/company/clrium/blog/463587/
25 -ConfigureAwait: часто задаваемые вопросы
26 -https://habr.com/ru/post/482354/
59 +----
27 27  
61 +=== Материалы: ===
62 +
63 +* [[Асинхронное программирование в C# 5.0 | O’Reilly>>path:/bin/view/%D0%9A%D0%BD%D0%B8%D0%B3%D0%B8/O%E2%80%99Reilly/%D0%90%D1%81%D0%B8%D0%BD%D1%85%D1%80%D0%BE%D0%BD%D0%BD%D0%BE%D0%B5%20%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5%20%D0%B2%20C%23%205.0%20%7C%20O%E2%80%99Reilly/]]
64 +* Async/await в C#: концепция, внутреннее устройство, полезные приемы
65 +[[https:~~/~~/habr.com/ru/post/470830/>>https://habr.com/ru/post/470830/||style="background-color: rgb(255, 255, 255);"]]
66 +* Асинхронные методы, async и await
67 +[[https:~~/~~/metanit.com/sharp/tutorial/13.3.php>>https://metanit.com/sharp/tutorial/13.3.php]]
68 +* Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET
69 +[[https:~~/~~/habr.com/ru/company/dododev/blog/435666/>>https://habr.com/ru/company/dododev/blog/435666/]]
70 +* Async/await в C#: подводные камни
71 +[[https:~~/~~/habr.com/ru/post/257221/>>https://habr.com/ru/post/257221/]]
72 +* (((
73 +Async/await и механизм реализации в C# 5.0
74 +[[https:~~/~~/habr.com/ru/post/260217/>>https://habr.com/ru/post/260217/]]
75 +)))
76 +* (((
77 +Async/await in C#: pitfalls
28 28  https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/
79 +)))
80 +* (((
81 +Асинхронность в C#. Разрушение легенд
29 29  https://techrocks.ru/2020/01/11/asynchrony-in-c-sharp/
83 +)))