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