170 похожих чатов

Зачем нужны async/await? В чём вообще смысл асинхронности? Т.е я понимаю:

есть GUI, который работает в основном потоке. Есть кнопка, при нажатии на которую происходит вызов метода HardWork(). Без многопоточности и вызова HardWork() в новом потоке GUI бы зависал на время выполнения HardWork(). Тут всё понятно. Есть более высокоуровневая оболочка в виде класса Task(ну и ещё эффективней использует потоки, берёт их из пула и прочие прелести). Позволяет писать +- адекватный код, в котором нет разделяемых состояний. Окей. Ключевое слово async пишут, чтобы await не путался с идентификатором. конструкция await SomeMethodAsync() разворачивается в var awaiter = SomeMethodAsync().GetAwaiter(); awaiter.OnCompleted{ var result = awaiter.GetResult(); ... остальные операторы }. Тут тоже всё понятно. Но такой вопрос, зачем это всё? Ведь по сути все уже "готовые" асинхронные функции нужно ждать сразу же. Ну например HttpResponseMessage response = await client.GetAsync("uri"); Может быть могли бы обьяснить? Привести примеры, где ждать не нужно.

16 ответов

1 просмотр

Чтобы не зависала твоя программа

Ты можешь и не ждать, или ждать в другом месте

Mikhail-Izmailov Автор вопроса
Rustam
Ты можешь и не ждать, или ждать в другом месте

Не могли бы вы привести пример, когда можно не ждать? Единственное, что у меня в голове сходится это методы с возвращаемым значением void, но для них можно просто вызвать было бы Task.Run(() => Method()) и забыть. И что на счёт ждать в другом месте?

Mikhail Izmailov
Не могли бы вы привести пример, когда можно не жда...

Когда таски друг на друга не влияют, в разной области. Тогда можно например запустить 2 таски и ждать потом var a = Run1(); var b = Run2(); var t1 = await a; var t2 = await b;

Mikhail-Izmailov Автор вопроса
Rustam
Когда таски друг на друга не влияют, в разной обла...

Ага, спасибо. Стало немного понятней.

Mikhail-Izmailov Автор вопроса
Rustam
Когда таски друг на друга не влияют, в разной обла...

А в ASP все действия контроллеров асинхронными делать нужно для того, чтобы сразу несколько независимых клиентов обратившись по одному адресу могли параллельно одно действие выполнить в контролере?

Mikhail Izmailov
А в ASP все действия контроллеров асинхронными дел...

Для каждого будет создан свой инстанс контроллера, и они будут обрабатываться одновременно(в разных потоках). Но да, это делается для того, чтобы можно было сделать больше за тот же промежуток времени

Mikhail Izmailov
А в ASP все действия контроллеров асинхронными дел...

Даже не асинхронные методы контролеров будут работать при одновременном получении нескольких запросов от разных клиентов)

Экономить потоки в пуле, для високонагружених серверов подходит очень.

Почему ждать сразу же. Есть Task.WhenAny и Task.WhenAll, например. Ну и там соль не столько GetAwaiter и OnCompleted, там SynchronizationContext.Current.Post() В зависимости от реализации контекста либо в тот же поток уходит продолжение, либо в тред пул, либо создаётся новый, либо напиши свой. Таким образом, есть высокоуровневый API, не зависящий от реализации работы с потоками, плюс синтаксический сахар, чтобы без callback-hell'ов.

Mikhail-Izmailov Автор вопроса
Тот самый Тимофей
Почему ждать сразу же. Есть Task.WhenAny и Task.Wh...

Спасибо большое! Про контекст синхронизации нужно побольше значит почитать, потому что не очень понял вообще зачем он. WhenAny вообще странная штука. Запускаешь 5 тасков и извлекаешь результат из той, которая выпонилась первая. Ничего кроме как запустить несколько методов, которые делают одно и тоже, но по-разному реализованы я больше не придумал (и то на стадии разработки). А про контекст синхронизации нужно лучше значит будет почитать, потому что в книге об этом не было ничего вроде бы )

Mikhail Izmailov
Спасибо большое! Про контекст синхронизации нужно...

https://docs.microsoft.com/en-us/archive/msdn-magazine/2011/february/msdn-magazine-parallel-computing-it-s-all-about-the-synchronizationcontext Вот статья, которую все рекомендуют. WhenAny очень нужная штука, когда есть большая очередь задач, и нужно их выполнять "максимально параллельно" (с лимитом по количеству одновременно выполняемых или занимаемой памяти, например). Ждёшь, когда любая выполнилась, смотришь не превышен ли лимит, достаёшь ещё одну из закромов и ставишь на выполнение.

Mikhail-Izmailov Автор вопроса
Тот самый Тимофей
https://docs.microsoft.com/en-us/archive/msdn-maga...

А, да. Хороший пример) Понятно теперь зачем Task.WhenAny. Извините возможно за глупые вопросы, я только учусь и ещё даже нигде не работал в этом направлении. Поэтому с реальными примерами туговато )

Mikhail Izmailov
А, да. Хороший пример) Понятно теперь зачем Task.W...

Сложная тема, наскоком не взять. Сам кучу статей перегуглил, пока более-менее понял, как работает.

Похожие вопросы

Обсуждают сегодня

читать файл максимально быстро? странный вопрос))
zamtmn
53
тоесть, указав return eax, сгенерируется никому ненужная инструкция mov eax,eax ?
Aiwan \ (•◡•) / _bot
24
Компания Elif ищет менеджера проектов, который будет заниматься поиском и ведением новых проектов. Прежде чем приступить к работе, вам нужно пройти наш недельный курс, где вы ...
Elif
1
Святости? Когда дотумкаешь что открытое лучше закрытого - кастани
zamtmn
9
я имею в виду официально интегрированный в телегу? в том плане что не сливает переписку с пользователем?
Andrey
9
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
А чего сейчас в моде вместо Error для эксепшенов? А то я тут внезапно узрел что он не рекомендуется :) У Try::Tiny какой-то совершенно ужасный синтаксис если надо конкретные э...
Denis F
19
Кто-нибудь решал проблему с автоматическим скроллингом к выбранной ячейке в TDBGrid в Lazarus? Проблема в том, что есть допустим 3 столбца, третий столбец виден наполовину, вк...
Дмитрий Логинов
1
Приветствуем всех! Устали без проектов? Если вы программист и хотите получать стабильные заказы, компания Elif предлагает вам недельный курс по поиску проектов и их ведению. ...
Elif
1
ты вот так хотел? а пурджить arg бесполезно это не макрос, вот рестроить arg смысл есть, но в конце области видимости, а не перед началом новой области видимости.
ProMiNick
7
Карта сайта