Изменения документа Некоторые моменты

Редактировал(а) Alexandr Fokin 2024/02/26 13:28

<
От версии < 1.6 >
отредактировано Alexandr Fokin
на 2024/02/25 00:20
К версии < 1.2 >
отредактировано Alexandr Fokin
на 2024/02/24 23:57
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -29,33 +29,9 @@
29 29   }
30 30   )
31 31   .ToArray();
32 -await Task.WhenAll(tasks);{{/code}}|(% style="width:776px" %)action1 будут выполнены одним потоком (который вызвал Enumarable) последовательно друг за другом (без какого-либо параллелизма). После этого происходит асинхронное ожидание и прерывание потока исполнения.
33 -action2 будет выполнено после ожидания при этом поток его выполнения зависит от параметров [[SynchronizationContext ~~| Контекст синхронизации>>doc:Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]] окружения (при этом могут исполняться параллельно друг другу в разных потоках.
34 -\\Такой подход подходит для ситуации, когда мы не стремимся параллелить action1 (он не является ресурсоемким).
35 -|(% style="width:48px" %)2)|(% style="width:456px" %){{code language="c#"}}var tasks = Enumerable
36 - .Range(0, 10)
37 - .Select(
38 - e => Task.Run(
39 - async () => {
40 - action1();
41 - await Task.Delay(TimeSpan.FromSeconds(10));
42 - action2();
43 - }
44 - )
45 - )
46 - .ToArray();
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 вариант т.к.
32 +await Task.WhenAll(tasks);{{/code}}|(% style="width:776px" %)Action1 будут выполнены одним потоком (который вызвал Enumarable) последовательно друг за другом. После этого происходит асинхронное ожидание и прерывание потока исполнения. action2 будет выполнено после ожидания при этом поток его выполнения зависит от параметров [[SynchronizationContext ~~| Контекст синхронизации>>doc:Разработка.NET.C#.Многопоточность и асинхронность.Асинхронность\. Async Await.SynchronizationContext | Контекст синхронизации.WebHome]] окружения.
33 +|(% style="width:48px" %)2)|(% style="width:456px" %) |(% style="width:776px" %)
34 +|(% style="width:48px" %) |(% style="width:456px" %) |(% style="width:776px" %)
59 59  
60 60  
61 61  )))