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

Почитал тред выше, вот что подметил, по порядку: 1. Task.Run всегда

выполняется в отдельном потоке, взятом из пула (см. https://docs.microsoft.com/en-us/dotnet/api/system.threading.tasks.task.run?view=netframework-4.7.2)
2. Несмотря на то, что будет попытка взять поток из пула, в нём может не быть свободного потока, и будет действительно создан новый поток (см. https://docs.microsoft.com/en-us/windows/desktop/procthread/thread-pools)
3. В том же потоке могут быть выполнены таски, которые
3.1 Уже созданы завершёнными, через Task.FromResult
3.2 Были возвращены методом, в котором выполнение не дошло до await
3.3 Представляют операцию, которая завершилась до начала ожидания
3.4 Достигли ожидания уже завершённого Task`а
(см. Alex Davies - Async in C#, глава "Async Methods Are Synchronous Until Needed")
4. Потоки из пула - фоновые (https://docs.microsoft.com/ru-ru/dotnet/standard/threading/the-managed-thread-pool#thread-pool-characteristics). Это означает, что UI поток не может быть потоком пула. Это, кстати, легко проверяется, когда пробуем узнать Thread.CurrentThread.IsThreadPoolThread, находясь в главном потоке
5. GUI элементы можно изменять только из UI потока (https://docs.microsoft.com/en-us/dotnet/framework/wpf/advanced/threading-model#overview-and-the-dispatcher). Другие потоки могут использовать UI поток для обновления GUI
6. Не нужно запускать Task.Run каждый раз "для асинхронности". Если задача оказалась короткоживущей (например, асинхронный запрос в зависимости от переменных не нужно было делать и мы вернулись рано) - то такой "асинхронный" метод будет жрать ресурсов больше, чем синхронный. По возможности используйте простые асинхронные методы.
7. Асинхронность и многопоточность:

Асинхронность - это когда мы запускаем выполнение задачи сейчас, а выполнена она будет "потом". До наступления этого "потом" текущий поток может выполнять какие-то другие задачи, в первую очередь это обеспечение отзывчивости UI, но и в без-UI-ных приложениях тоже прекрасно, когда потоки не простаивают без работы, ожидая, например, ответа от жёсткого диска / БД. Поток - это ресурсы, и их количество необходимо минимизировать.

Разделим асинхронность на два случая:

1. Мы запускаем задачу ввода-вывода, которые могут занимать долгое время (чтение файла, скачивание чего-либо из сети и т.п., то есть вещи длительные по есстественным причинам)
2. Вычислительные задачи, которые мы хотим сделать в отдельном потоке (потоках) и продолжить работу далее

Первый случай - когда асинхронность никак не связана с многопоточностью. В зависимости от реализации, либо дополнительных потоков вообще нет, либо есть один поток на все запросы, который обрабатывает ответы
Второй случай - это когда асинхронность = многопоточность. Мы запускаем задачу/задачи в отдельном потоке для разгрузки текущего (скорее всего, это разгрузка UI)

3 ответов

7 просмотров

А вот и перечень ситуаций когда выполнение асинхронного кода не выходит за рамки текущего потока, спасибо)

3.2 & 3.3 не одне і те ж?

Ого, круто просуммировал! Твой текст?

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта