Изменения документа Многопоточность и асинхронность
Редактировал(а) Alexandr Fokin 2023/01/11 15:19
<
>
отредактировано Alexandr Fokin
на 2020/06/06 10:20
на 2020/06/06 10:20
отредактировано Alexandr Fokin
на 2020/01/05 22:47
на 2020/01/05 22:47
Изменить комментарий:
Update document after refactoring.
Комментарий
-
Свойства страницы (2 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Родительский документ
-
... ... @@ -1,1 +1,1 @@ 1 -Разработка.NET. C#.WebHome1 +Разработка.NET.WebHome - Содержимое
-
... ... @@ -10,7 +10,7 @@ 10 10 Это самые часто используемые конструкции для синхронизации потоков. Реализуют идею критической секции: то есть код, написанный между вызовами Monitor.Enter, Monitor.Exit на одном ресурсе может быть выполнен в один момент времени лишь одним потоком. Оператор lock является синтаксическим сахаром вокруг вызовов Enter/Exit обернутых в try-finally. Приятной особенностью реализации критической секции в .NET является возможность повторного входа в нее для одного и того же потока. 11 11 12 12 Mutex нужен для синронизации на уровне ОС. (Может использоваться несколькими приложениями) 13 -Семафоры позволяют ограничить доступ определенным количеством потоков.13 +Семафоры позволяют ограничить доступ определенным количеством объектов. 14 14 15 15 ReaderWriterLockSlim 16 16 Либо много потоков читает, либо 1 поток пишет ... ... @@ -17,19 +17,16 @@ 17 17 18 18 При использовании инструментов важно освобождать освобождать блокировку, даже если в процессе выполнения вылетит exception. 19 19 Шаблон: 20 - 21 -{{code language="c#"}} 22 22 try 23 23 { 24 24 LockSection(); 25 25 //... Action 26 26 } 27 -cat ch {}25 +cathc {} 28 28 finally 29 29 { 30 30 UnlockSection(); 31 31 } 32 -{{/code}} 33 33 34 34 Примеры 35 35 Запись в один и тот же файл с разных потоков. (В определенный момент времени в файл записывает только 1 поток) ... ... @@ -62,20 +62,13 @@ 62 62 Асинхронный код записывается в синхронном виде (Выглядит последовательно), но при этом в момент выполнения задач, выполняющий поток не простаивает, а освобождается и может выполнять другие задачи. 63 63 В случае desctop приложения это позволяет не блокировать UI (зависание основного потока во время выполнения операций). 64 64 В случае web приложений, данный подход позволяет обрабатывать больше активных подключений. (Поток обрабатывает запрос, сталкивается с асинхронной операцией, освобождается и может обработать другие входящие запросы. При окончании асинхронной операции тот-же или другой поток продолжит выполнение) Т.е. прирост не в скорости работы, а в пиковой нагрузке по кол-ву соединений, за счет освобождения потоков, ожидающих завершения асинхронных операций. При этом присутсвуют небольшие накладные расходы, связанные с работой Async/Await. 65 -[[devblogs.microsoft| ConfigureAwait FAQ>>https://devblogs.microsoft.com/dotnet/configureawait-faq/?utm_source=csharp&utm_medium=email&utm_campaign=digest]] 66 66 67 67 Материалы: 68 -* [[Habr Async/await в C#: концепция, внутреннее устройство, полезные приемы>>https://habr.com/ru/post/470830/]] 69 -* [[Metanit Aсинхронное программирование>>https://metanit.com/sharp/tutorial/13.3.php]] 70 -* [[Habr Асинхронный рассинхрон: антипаттерны в работе с async/await в .NET>>https://habr.com/ru/company/dodopizzadev/blog/435666/]] 71 -* [[Habr Async/await в C#: подводные камни>>https://habr.com/ru/post/257221/]] 72 -* [[Habr Async/await и механизм реализации в C# 5.0>>https://habr.com/ru/post/260217/]] 64 +* [[Async/await в C#: концепция, внутреннее устройство, полезные приемы>>https://habr.com/ru/post/470830/]] 73 73 74 74 67 + 75 75 **Taskcompletionsource** 76 76 77 77 Материалы: 78 78 * [[В-чем-смысл-taskcompletionsourcet-и-когда-его-лучше-использовать>>https://ru.stackoverflow.com/questions/780270/%D0%92-%D1%87%D0%B5%D0%BC-%D1%81%D0%BC%D1%8B%D1%81%D0%BB-taskcompletionsourcet-%D0%B8-%D0%BA%D0%BE%D0%B3%D0%B4%D0%B0-%D0%B5%D0%B3%D0%BE-%D0%BB%D1%83%D1%87%D1%88%D0%B5-%D0%B8%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D0%BE%D0%B2%D0%B0%D1%82%D1%8C]] 79 - 80 - 81 -**[[Конкурентность в C#. Асинхронное, параллельное и многопоточное программирование.>>https://wiki.denhome.ru/bin/view/Книги/Конкурентность%20в%20C%23.%20Асинхронное%2C%20параллельное%20и%20многопоточное%20программирование.%20%7C%20O’Reilly]]**