Изменения документа Асинхронность. Async Await
Редактировал(а) Alexandr Fokin 2025/04/09 12:46
<
>
отредактировано Alexandr Fokin
на 2025/04/09 12:35
на 2025/04/09 12:35
отредактировано Alexandr Fokin
на 2022/12/31 15:31
на 2022/12/31 15:31
Изменить комментарий:
К данной версии нет комментариев
Комментарий
-
Свойства страницы (2 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Родительский документ
-
... ... @@ -1,1 +1,1 @@ 1 -Разработка.NET.C#.Многопоточность и асинхронность.WebHome1 +Разработка.NET.C#.Многопоточность.WebHome - Содержимое
-
... ... @@ -1,65 +1,45 @@ 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 - End 11 -Блокирующий подход. 12 -|(% style="width:233px" %)Event-based Asynchronous|(% style="width:1052px" %)Callback, event. 13 -Неблокирующий подход, но код менее удобный и менее читаемый. 14 -|(% style="width:233px" %)TAP (Task-based asynchronous)|(% style="width:1052px" %)Task (Promise/Feature) 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 15 15 Async Await 16 -[[SynchronizationContext ~~| Контекст синхронизации>>Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]]. 17 -Неблокирующий подход, при этом код пишется в синхронном (последовательном) виде. 18 -|(% style="width:233px" %)Green threads|(% style="width:1052px" %)Подход к механизму, когда на уровне кода не используется никаких дополнительных пометок о асинхронном исполнении, а ответственность за выявление асинхронных блоков и их обработка (асинхронное неблокирующее ожидание) лежит на среде выполнения приложения. 19 -Можно сказать, что формат кода приближен к шаблону TAP, но не требуется указывать в коде async методы и await - места ожидания. 21 +[[SynchronizationContext | Контекст синхронизации>>Разработка.NET.C#.Многопоточность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]] 20 20 ))) 21 -|(% style="width:177px" %)Подробнее о 22 -TAP ~| Async/Await|(% style="width:1308px" %)((( 23 -Более мягкий подход к асинхронности. 24 -Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения асинхронного кода, выполняющий поток не блокируется, а освобождается и может выполнять другие задачи. 25 25 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 26 27 -|(% style="width:79px" %)Desktop (GUI)|(% style="width:1443px" %)Позволяет не блокировать UI (зависание основного потока во время выполнения долгих операций [[Event loop>>doc:Архитектура и модели.Модели.Event loop.WebHome]]). 28 -Когда встречается реальная асинхронная операция 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. 29 29 |(% style="width:79px" %)Web|(% style="width:1443px" %)((( 30 -Позволяет обрабатывать большее кол-во параллельных задач (запросов) меньшим кол-во потоков. 31 -(Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается (возвращается в пул) и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток из пула продолжит выполнение). 38 +Позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение). 32 32 33 33 Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций. 34 34 При этом присутствуют небольшие накладные расходы, связанные с работой Async/Await. 35 - 36 -Позволяет пулу потоков обходиться меньшим количеством потоков за счет отсутствия (бесполезной) блокировки потока на ожидании завершения асинхронной операции. 37 37 ))) 38 -))) 39 -|(% style="width:177px" %)Материалы:|(% style="width:1308px" %)((( 40 -|(% style="width:106px" %)Книги|(% style="width:1184px" %)((( 41 -* [[Асинхронное программирование в C# 5.0 | O’Reilly>>doc:Книги.O’Reilly.Асинхронное программирование в C# 5\.0 | O’Reilly.WebHome]] 42 -* [[CLR via C# | Джеффри Рихтер>>doc:Книги.CLR via C# | Джеффри Рихтер.WebHome]] 43 -))) 44 -|(% style="width:106px" %)Статьи|(% style="width:1184px" %)((( 45 -* Async/await в C#: концепция, внутреннее устройство, полезные приемы 46 -[[https:~~/~~/habr.com/ru/post/470830/>>https://habr.com/ru/post/470830/||style="background-color: rgb(255, 255, 255);"]] 47 -* Асинхронные методы, async и await 48 -[[https:~~/~~/metanit.com/sharp/tutorial/13.3.php>>https://metanit.com/sharp/tutorial/13.3.php]] 49 -* Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET 50 -[[https:~~/~~/habr.com/ru/company/dododev/blog/435666/>>https://habr.com/ru/company/dododev/blog/435666/]] 51 -* Async/await в C#: подводные камни 52 -[[https:~~/~~/habr.com/ru/post/257221/>>https://habr.com/ru/post/257221/]] 53 -* Async/await и механизм реализации в C# 5.0 54 -[[https:~~/~~/habr.com/ru/post/260217/>>https://habr.com/ru/post/260217/]] 55 -* Async/await in C#: pitfalls 56 -https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/ 57 -* Асинхронность в C#. Разрушение легенд 58 -https://techrocks.ru/2020/01/11/asynchrony-in-c-sharp/ 59 -* RadioDotNet. Async practices, breaking changes, time provider 60 -[[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]] 61 -))) 62 -))) 63 63 64 64 ---- 65 65 ... ... @@ -83,4 +83,39 @@ 83 83 #end 84 84 {{/velocity}} 85 85 86 - 66 +---- 67 + 68 +==== Taskcompletionsource ==== 69 + 70 +Taskcompletionsource - инструмент позволяющий преобразовать некоторые другие виды асинхронного кода к формату паттерну TAP. 71 + 72 +Материалы: 73 + 74 +* В чем смысл TaskCompletionSource<T> и когда его лучше использовать? 75 +[[https:~~/~~/ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать>>https://ru.stackoverflow.com/questions/780270/В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать]] 76 + 77 +---- 78 + 79 +=== Материалы: === 80 + 81 +* [[Асинхронное программирование в C# 5.0 | O’Reilly>>doc:Книги.O’Reilly.Асинхронное программирование в C# 5\.0 | O’Reilly.WebHome]] 82 +* Async/await в C#: концепция, внутреннее устройство, полезные приемы 83 +[[https:~~/~~/habr.com/ru/post/470830/>>https://habr.com/ru/post/470830/||style="background-color: rgb(255, 255, 255);"]] 84 +* Асинхронные методы, async и await 85 +[[https:~~/~~/metanit.com/sharp/tutorial/13.3.php>>https://metanit.com/sharp/tutorial/13.3.php]] 86 +* Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET 87 +[[https:~~/~~/habr.com/ru/company/dododev/blog/435666/>>https://habr.com/ru/company/dododev/blog/435666/]] 88 +* Async/await в C#: подводные камни 89 +[[https:~~/~~/habr.com/ru/post/257221/>>https://habr.com/ru/post/257221/]] 90 +* ((( 91 +Async/await и механизм реализации в C# 5.0 92 +[[https:~~/~~/habr.com/ru/post/260217/>>https://habr.com/ru/post/260217/]] 93 +))) 94 +* ((( 95 +Async/await in C#: pitfalls 96 +https://enterprisecraftsmanship.com/posts/pitfalls-of-async-await/ 97 +))) 98 +* ((( 99 +Асинхронность в C#. Разрушение легенд 100 +https://techrocks.ru/2020/01/11/asynchrony-in-c-sharp/ 101 +)))