Изменения документа Примитивы синхронизации
Редактировал(а) Alexandr Fokin 2023/10/09 10:03
<
>
отредактировано Alexandr Fokin
на 2022/10/04 17:50
на 2022/10/04 17:50
отредактировано Alexandr Fokin
на 2023/01/12 13:51
на 2023/01/12 13:51
Изменить комментарий:
К данной версии нет комментариев
Комментарий
-
Свойства страницы (2 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Родительский документ
-
... ... @@ -1,1 +1,1 @@ 1 -Разработка.NET.C#.Многопоточность.WebHome 1 +Разработка.NET.C#.Многопоточность и асинхронность.WebHome - Содержимое
-
... ... @@ -1,4 +1,4 @@ 1 -=== Типы примитивов .===1 +=== Типы примитивов === 2 2 3 3 |Конструкции пользовательского режима| 4 4 |Конструкции режима ядра| ... ... @@ -18,25 +18,35 @@ 18 18 1. Класс, содержащий методы, которые помимо операции чтения/записи накладывают ограничение (барьер), не позволяющее процессору менять порядок выполнения команд. 19 19 ))) 20 20 |(% style="width:590px" %)Interlocked 21 -[[https:~~/~~/learn.microsoft.com/ru-ru/dotnet/api/system.threading.interlocked?view=net-5.0>>https://learn.microsoft.com/ru-ru/dotnet/api/system.threading.interlocked?view=net-5.0]]|(% style="width:892px" %) 21 +[[https:~~/~~/learn.microsoft.com/ru-ru/dotnet/api/system.threading.interlocked?view=net-5.0>>https://learn.microsoft.com/ru-ru/dotnet/api/system.threading.interlocked?view=net-5.0]]|(% style="width:892px" %)Предоставляет набор некоторых операций, гарантирующих атомарность выполнения. 22 22 23 23 | | 24 -|Monitor и конструкция Lock|((( 25 -Реализуют идею критической секции: то есть код, написанный между вызовами Monitor.Enter, Monitor.Exit на одном ресурсе может быть выполнен в один момент времени лишь одним потоком. 26 - 27 -Оператор lock оберткой над Enter/Exit обернутых в try-finally. 24 +|Monitor|((( 25 + Реализуют идею критической секции. Ограничивает степень параллелизма на секциях, находящихся после Monitor.Enter, одним потоком. 28 28 ))) 29 -|Semaphore|Семафоры позволяют ограничить доступ выполнения кода определенным количеством потоков. 27 +|Lock|Оператор lock является оберткой над классом Monitor, его операциями Enter/Exit, обернутыми в try-finally. 28 +|Semaphore 29 +SemaphoreSlim|Семафоры позволяют ограничить доступ выполнения кода определенным количеством потоков. 30 30 |Mutex|Используется для синхронизации на уровне операционной системы. 31 31 Может использоваться несколькими приложениями в рамках одной ОС. 32 32 |ReaderWriterLock 33 -ReaderWriterLockSlim|Либо много потоков читает, либо 1 поток пишет. 34 -| | 33 +ReaderWriterLockSlim|Позволяет ограничить параллелизм либо 1 писателем, либо многими читателями. 34 +|AutoResetEvent 35 +ManualResetEven|Имеет 2 состояния (взведен и не взведен). 36 +Позволяет ожидать взведенного состояния. 37 +Содержит методы для взведения. 38 +|CountdownEvent|При инициализации задается значение счетчика. 39 +Позволяет ожидать, когда значение счетчика будет равно 0. 40 +Метод уменьшающий счетчик. 41 +|Spin*| 35 35 36 36 ---- 37 37 38 -Материалы :45 +=== Материалы === 39 39 47 +* [[Блокировки>>doc:Архитектура и модели.Блокировки.WebHome]] 48 +* Общие сведения о примитивах синхронизации 49 +[[https:~~/~~/learn.microsoft.com/ru-ru/dotnet/standard/threading/overview-of-synchronization-primitives?source=recommendations>>https://learn.microsoft.com/ru-ru/dotnet/standard/threading/overview-of-synchronization-primitives?source=recommendations]] 40 40 * .NET: Инструменты для работы с многопоточностью и асинхронностью. Часть 1 41 41 [[https:~~/~~/habr.com/ru/post/452094>>https://habr.com/ru/post/452094]] 42 42 * .NET: Инструменты для работы с многопоточностью и асинхронностью. Часть 2