Изменения документа Асинхронность. Async Await
Редактировал(а) Alexandr Fokin 2025/04/09 12:46
<
>
отредактировано Alexandr Fokin
на 2025/04/09 12:31
на 2025/04/09 12:31
отредактировано Alexandr Fokin
на 2021/12/25 17:52
на 2021/12/25 17:52
Изменить комментарий:
Update document after refactoring.
Комментарий
-
Свойства страницы (2 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Родительский документ
-
... ... @@ -1,1 +1,1 @@ 1 -Разработка.NET.C#.Многопоточность и асинхронность.WebHome1 +Разработка.NET.C#.Многопоточность.WebHome - Содержимое
-
... ... @@ -1,91 +1,29 @@ 1 -|(% style="width:177px" %)Подходы к реализации асинхронного кода.|(% style="width:1308px" %)((( 2 -На протяжении истории существовало несколько подходов к реализации асинхронного кода. Подход на основе async-await является наиболее молодым. 3 -Зачастую асинхронность связана с операциями ввода/вывода (Файловая система, Базы данных, Http запросы, операция ожидания (Task.Delay) и другое), где присутствует сравнительно большое ожидание в котором поток не задействован. 1 +**Async/Await** 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/]] 3 +Понятие конктеста выполнения. 7 7 8 -|(% style="width:233px" %)((( 9 -APM 10 -)))|(% style="width:1052px" %)Begin 11 -End (блокирующий) 12 -|(% style="width:233px" %)((( 13 -Event-based Asynchronous 14 -)))|(% style="width:1052px" %)((( 15 -Callback 16 -Event 17 -))) 18 -|(% style="width:233px" %)TAP (Task-based asynchronous)|(% style="width:1052px" %)((( 19 -Task (Promise/Feature) 20 -Async Await 21 -[[SynchronizationContext | Контекст синхронизации>>Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]] 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 28 Более мягкий подход к асинхронности. 29 -Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения асинхронного кода, выполняющий поток не блокируется, а освобождается и может выполнять другие задачи. 6 +Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения задач, выполняющий поток не простаивает, а освобождается и может выполнять другие задачи. 7 +В случае desctop приложения это позволяет не блокировать UI (зависание основного потока во время выполнения операций). 8 +В случае web приложений, данный подход позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение) Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций. При этом присутсвуют небольшие накладные расходы, связанные с работой Async/Await. 30 30 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]] 31 31 32 -|(% style="width:79px" %)Desktop (GUI)|(% style="width:1443px" %)Позволяет не блокировать UI (зависание основного потока во время выполнения долгих операций [[Event loop>>doc:Архитектура и модели.Модели.Event loop.WebHome]]). 33 -Когда встречается реальная асинхронная операция UI Thread освобождается и идет обрабатывать другие события графического интерфейса. После того, как асинхронная операция будет завершена, код идущей за ней может продолжить выполнение в UI Thread (или в другом потоке из пула). 34 -|(% style="width:79px" %)Web|(% style="width:1443px" %)((( 35 -Позволяет обрабатывать большее кол-во параллельных задач (запросов) меньшим кол-во потоков. 36 -(Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается (возвращается в пул) и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток из пула продолжит выполнение). 37 37 38 -Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций. 39 -При этом присутствуют небольшие накладные расходы, связанные с работой Async/Await. 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/]] 40 40 41 -Позволяет пулу потоков обходиться меньшим количеством потоков за счет отсутствия (бесполезной) блокировки потока на ожидании завершения асинхронной операции. 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" %)((( 50 -* Async/await в C#: концепция, внутреннее устройство, полезные приемы 51 -[[https:~~/~~/habr.com/ru/post/470830/>>https://habr.com/ru/post/470830/||style="background-color: rgb(255, 255, 255);"]] 52 -* Асинхронные методы, async и await 53 -[[https:~~/~~/metanit.com/sharp/tutorial/13.3.php>>https://metanit.com/sharp/tutorial/13.3.php]] 54 -* Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET 55 -[[https:~~/~~/habr.com/ru/company/dododev/blog/435666/>>https://habr.com/ru/company/dododev/blog/435666/]] 56 -* Async/await в C#: подводные камни 57 -[[https:~~/~~/habr.com/ru/post/257221/>>https://habr.com/ru/post/257221/]] 58 -* Async/await и механизм реализации в C# 5.0 59 -[[https:~~/~~/habr.com/ru/post/260217/>>https://habr.com/ru/post/260217/]] 60 -* Async/await in C#: pitfalls 61 -https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/ 62 -* Асинхронность в C#. Разрушение легенд 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 -))) 67 -))) 68 68 69 ----- 23 +ConfigureAwait, кто виноват и что делать? 24 +https://habr.com/ru/company/clrium/blog/463587/ 25 +ConfigureAwait: часто задаваемые вопросы 26 +https://habr.com/ru/post/482354/ 70 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 - 28 +https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/ 29 +https://techrocks.ru/2020/01/11/asynchrony-in-c-sharp/