Изменения документа Некоторые моменты
Редактировал(а) Alexandr Fokin 2024/02/26 13:28
<
>
отредактировано Alexandr Fokin
на 2024/02/25 00:03
на 2024/02/25 00:03
отредактировано Alexandr Fokin
на 2024/02/25 00:20
на 2024/02/25 00:20
Изменить комментарий:
К данной версии нет комментариев
Комментарий
-
Свойства страницы (1 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Содержимое
-
... ... @@ -31,6 +31,7 @@ 31 31 .ToArray(); 32 32 await Task.WhenAll(tasks);{{/code}}|(% style="width:776px" %)action1 будут выполнены одним потоком (который вызвал Enumarable) последовательно друг за другом (без какого-либо параллелизма). После этого происходит асинхронное ожидание и прерывание потока исполнения. 33 33 action2 будет выполнено после ожидания при этом поток его выполнения зависит от параметров [[SynchronizationContext ~~| Контекст синхронизации>>doc:Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]] окружения (при этом могут исполняться параллельно друг другу в разных потоках. 34 +\\Такой подход подходит для ситуации, когда мы не стремимся параллелить action1 (он не является ресурсоемким). 34 34 |(% style="width:48px" %)2)|(% style="width:456px" %){{code language="c#"}}var tasks = Enumerable 35 35 .Range(0, 10) 36 36 .Select( ... ... @@ -43,8 +43,18 @@ 43 43 ) 44 44 ) 45 45 .ToArray(); 46 -await Task.WhenAll(tasks);{{/code}}|(% style="width:776px" %)При таком вызове на каждый отдельный элемент будет запущена отдельная задача через планировщик. Действия будут выполняться параллельно друг другу (в том числе и action1) в разных потоках. 47 -|(% style="width:48px" %) |(% style="width:456px" %) |(% style="width:776px" %) 47 +await Task.WhenAll(tasks);{{/code}}|(% style="width:776px" %)При таком вызове на каждый отдельный элемент будет запущена отдельная задача через планировщик. Действия будут выполняться параллельно друг другу (в том числе и action1) в разных потоках. Будет запланировано 10 задач. 48 +По умолчанию код, внутри делегата Task.Run будет выполнен без контекста синхронизации, таким образом action2 будет запланирован к исполнению на потоке их пула. 49 +\\Такой подход не очень хорош, если каждая операция не является ресурсоемкой с точки зрения процессора. 50 +|(% style="width:48px" %)3) |(% style="width:456px" %){{code language="c#"}}await Parallel.ForEachAsync( 51 + Enumerable.Range(0, 10), 52 + async (e, t) => 53 + { 54 + action1(); 55 + await Task.Delay(TimeSpan.FromSeconds(10)); 56 + action2(); 57 + } 58 + );{{/code}}|(% style="width:776px" %)Данный метод позволяет выполнять действия параллельно, но при этом будет более экономичным чем 2 вариант т.к. 48 48 49 49 50 50 )))