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

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

<
От версии < 6.4 >
отредактировано Alexandr Fokin
на 2025/04/09 12:32
К версии < 3.8 >
отредактировано Alexandr Fokin
на 2022/12/15 10:57
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

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