Основы Asyncio

Поділитися
Вставка
  • Опубліковано 14 січ 2025

КОМЕНТАРІ • 136

  • @IlyaErokhin-uv7vx
    @IlyaErokhin-uv7vx 8 місяців тому +38

    Единственное видео, где автор смог понятным образом донести суть асинхронщины, к тому же прошелся ПОСТРОЧНО по коду расъяснив его в деталях, благодарю

  • @podgorniy.r
    @podgorniy.r 9 місяців тому +14

    Только запустил и сразу понял, что это лучшее видео на данную тему из свежих материалов!

  • @danilfighter6179
    @danilfighter6179 10 місяців тому +28

    Очень жду вторую часть. Спасибо большое за такой информативный и самое главное - бесплатный контент. Ты лучший!

    • @PythonRussian
      @PythonRussian  10 місяців тому +6

      спасибо, но уточните на всякий случай о какой второй части речь?)) у меня дальше по планам мультипроцессинг и давно просят рекурсию

    • @danilfighter6179
      @danilfighter6179 10 місяців тому

      @@PythonRussian Может будет более детальный разбор 🥺🥵

    • @АлексейТаганрогов
      @АлексейТаганрогов 10 місяців тому +2

      Не, ну реально лучший. Причём с большим отрывом!

    • @user-buser_eto_ja
      @user-buser_eto_ja 10 місяців тому

      @@PythonRussian Рекурсию, да с большим нетерпением ждем!

    • @Nicktimes
      @Nicktimes 10 місяців тому

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

  • @AnastasiaDulatova
    @AnastasiaDulatova 7 годин тому

    Это просто какой-то нереальный шедевр! Так понятно объяснить такую сложную тему - это сверхмастрество. Огромный респект автору.

  • @millersane5965
    @millersane5965 3 місяці тому +3

    Потрясающее видео, все в голове встало на свои места. Много было не понятно раньше в особенности await, но после данного ролика асинхронность стала еще одним навыком для меня. Также хотелось бы отметить пример с гроссмейстером , так как поток один, то 1000 корутин не будет работать также быстро как 15 , одним словом ЛАЙК!

  • @SemyonKalyakulin
    @SemyonKalyakulin 10 місяців тому +8

    все четко по сути. Очень наглядно.
    Всем рекомендую ваш канал!)

  • @MakeMoney-rx7ux
    @MakeMoney-rx7ux 26 днів тому +1

    Очень понятно все разжевано. Благодарность за видос.

  • @ProficusLets
    @ProficusLets 9 місяців тому +3

    Спасибо за такой объемный интересный и детальный гайд. Продолжай развивать канал!

  • @andrePrylepa
    @andrePrylepa 5 місяців тому +3

    Лучшее объяснение основ асинхрого программирования на питоне в русскоязычном секторе. Большое вам спасибо!

  • @digitale231
    @digitale231 4 місяці тому +2

    десятки комментаторов уже сказали, что это лучший рассказ про асинхронку, но я бы повторил)) очень классно, что не просто бросаются факты в слушателя, а дальше сам разберется, а по каждому вопросу размусоливается до отдельных слов каждый момент, формируется прочное начальное понимание темы и уверенность в знаниях) Как и многие, думаю, пришел с курса Павла Хошева по парсингу, не знаю, как дела обстоят в его курсе по асинхронке, но в случае с парсингом подход был ровно обратный подходу этого видео - никакого углубления что под капотом, вот вам пример парсера и ключевые слова, вперед. В итоге даже две единственные задачи дались с трудом в том модуле и в итоге ноль понимания сложилось, благо, сие видео помогло разобраться, большое спасибо, подписочку оформил))

  • @dilirink9222
    @dilirink9222 9 місяців тому +3

    спасибо! всегда было лень разобрать эту тему) тут за первые 20 минут прочухал как оно работает)

  • @aradarbinyan312
    @aradarbinyan312 8 місяців тому +4

    37:53 блин как же это в точку. У меня было ровно то что говорит автор, асинхронный телеграм бот а внутри него синхронные библиотеки. Вот прям один в один. Автору видео кстати респект за качественное видео! Это пока лучшее пояснение ассинхронисти в Python которое я видел. Продолжай в том же духе!

  • @amalshakov
    @amalshakov 7 місяців тому +4

    Спасибо. 3 дня смотрю про асинхронку. У вас очень хорошо получилось!

  • @antonaverchanko3387
    @antonaverchanko3387 3 місяці тому +1

    Просто нет слов. Это лучшая подача материала, которую я встречал на просторах Ютуба.
    Автору успехов в развитии канала и огромный респект.

  • @АлександрНетесов-о9у
    @АлександрНетесов-о9у 4 місяці тому +1

    Как только мне становилось что-то не понятно, автор, как будто читая мои мысли, это пояснял. Это талант, большое спасибо.

  • @alexeydanilov1557
    @alexeydanilov1557 5 місяців тому +1

    Объяснение просто супер - чётко, ясно и понятно. Автор разобрал все вопросы, которые могли бы возникнуть при взгляде на приведённый код.

  • @СергейФролов-ъ5я
    @СергейФролов-ъ5я 15 днів тому +1

    Большое спасибо!

  • @nebesalo
    @nebesalo 2 місяці тому +2

    Лучший, респект

  • @understandwhat
    @understandwhat 4 місяці тому +2

    Автор большой молодец!

  • @JoySenseKO
    @JoySenseKO 2 місяці тому +2

    Вы лучший ❤

  • @n0rmaLman
    @n0rmaLman 4 місяці тому +4

    Ответ на вопрос 25:18 очень простой. Я его нашел в книге Мэттью Фаулера. Там от пишет, что await запускает очередную итерацию цикла событий, а это зничит, что запускаются ВСЕ ожидающие выполнения задачи. То есть, когда в вашем примере await вы поставили во всех строках сперва запустился цикл с первой задачей (остальные еще не созданы), затем со второй (первая уже выполнена, а третья пока не создана), затем с третьей. Когда await у вас только в последней строке все три задачи запускаются сразу, так как уже находятся в цикле событий. В книге подобный пример не вызывает вопросов, так как там автор сперва явно создает все задачи 'task1=asyncio.create_task(task_one())' а уже потом их ВСЕХ ставит на паузу 'await task1'.
    В общем, ваше объяснение этого момента немного сбивает с толку. Но все равно спасибо, так как заставили покопаться в этом вопросе и разобраться.

    • @Enerdzizer
      @Enerdzizer 2 місяці тому

      По моему действительно в видео путаница какаято. Сначала про await говорится что это некоторая операция которая ставит выполнение функции на паузу и передаёт управление другим функциям находящимся в цикле событий (19:56) и ждущим своей очереди , а потом внезапно про await говорится что это блокирующая операция и мы должны дождаться пока функция не отработает (25:18).

    • @guiterenzog2723
      @guiterenzog2723 Місяць тому

      ВСЕ задачи запуститься не могут. Из них выбирается одна, которая начинает выполнение

  • @ЕгорШишкин-ф6ч
    @ЕгорШишкин-ф6ч 7 місяців тому +2

    Спасибо за контент!
    При поиске материалов по asyncio сразу нашел твое видео, но из-за непривлекательности заставки пропустил.
    После продолжительного чтения документации и статей на Хабре, понял, что нет понимания базы. Вернулся к твоему видео и все стало максимально понятно.

    • @PythonRussian
      @PythonRussian  7 місяців тому +1

      ну ты чего -о книге по обложке судишь?))) да и заставку конкретно в 1 этом случае сгенерил ИИ, ты прям обидел нарождающийся скайнет =) По основам - очень хорошо, что понял и начал их осваивать, я сам в свое время забуксовал, потому что начал не с основ, а с синтаксиса, думал все очевидно.

  • @kotart3938
    @kotart3938 7 місяців тому +1

    Спасибо большое за видео. Тут явно более доступно автор объясняет тему, все понял, начинаем работу))

  • @fragtv8163
    @fragtv8163 8 місяців тому +2

    Просто гений, легенда объяснений. Я так счастлив не был давно😅

    • @PythonRussian
      @PythonRussian  8 місяців тому

      удивлен что видео по асинке может вызвать такую реакцию, но рад

  • @ynchk.
    @ynchk. 6 місяців тому

    Автору огромное спасибо! Разъяснил буквально на пальцах

  • @nadyamoscow2461
    @nadyamoscow2461 4 місяці тому

    Огромное спасибо! отличное введение в asyncio. И отдельная благодарность за кусочек "из реальной жизни" - про запросы. Как раз пишу себе программку для скачивания сериала с сайта. Там и попробую применить.

  • @otbephncb4458
    @otbephncb4458 10 місяців тому +12

    Корутина засыпает, просыпается мафия)

  • @ИванЗавьялов-о4п
    @ИванЗавьялов-о4п 8 місяців тому +1

    спасибо большое, все очень доходчиво, интересно и очень полезно.

  • @BaDiTaRaKaN
    @BaDiTaRaKaN 7 місяців тому +1

    Наконец-то я понял, что такое асинхронное программирование. Спасибо большое

  • @Mesedal
    @Mesedal 10 місяців тому +1

    Большое спасибо за понятное объяснение!

  • @vladmob
    @vladmob 7 місяців тому +1

    Просто великолепно!

  • @cherezov_mikhail
    @cherezov_mikhail Місяць тому +1

    🔥

  • @ABDULHAMIDGULOV
    @ABDULHAMIDGULOV 4 місяці тому +2

    Вот это оригинальная концовка

  • @SashaBorandi
    @SashaBorandi 10 місяців тому +3

    Очень все разжевано, спасибо

  • @nikolazzzer7087
    @nikolazzzer7087 7 місяців тому +1

    Наконец то нашел урок где объяснили что такое asyncio

  • @why_me_why_not
    @why_me_why_not 4 місяці тому +3

    Указать await three() и gather - это не одно и то же поведение. В этом примере работает одинаково. Но поставь в корутине one() паузу больше, чем в three() - в консоли уже не будет 'stop one', т.к. мы не указали явно, что ждем результата one(). А в случае с gather цикл дождется выполнения всех задач, в консоли будет полный вывод.

  • @davidbibi3138
    @davidbibi3138 10 місяців тому +2

    Спасибо за видеоурок :)

  • @leva1672
    @leva1672 2 місяці тому +2

    Чел красавчик

  • @Snerg-o9g
    @Snerg-o9g 3 місяці тому

    Огромное спасибо. Как раз пригодится в FastApi.

  • @Культурная_Столица
    @Культурная_Столица 10 місяців тому +1

    Еще не смотрела, лайк поставила. Потом зайду посмотрю))

  • @Давид-у3д7ж
    @Давид-у3д7ж 7 місяців тому

    Кратко и очень понятно, рекомендую!

  • @АртемийРенев
    @АртемийРенев 3 місяці тому +1

    пасиба большое!

  • @alexeymatveev9031
    @alexeymatveev9031 10 місяців тому

    Отлично, давно ждал, спасибо!

  • @ngbaranov
    @ngbaranov 9 місяців тому

    Очень хорошо, всё по полочкам, всё понятно

  • @TheZekas
    @TheZekas Місяць тому

    Есть замечание, управление event_loop передаётся не на каждом await. Лишь на том моменте, где возвращается объект Future. Так если мы сделаем await корутины, у которой блокирующий код (по типу принтов) корутина не заморозится, а начнёт его выполнять никуда не убегая в другую задачу, важно понимать, что переход на другую задачу происходит только когда мы ожидаем объект future

  • @nicasmirnovaa
    @nicasmirnovaa 5 місяців тому

    огромное спасибо за видео!

  • @denoxi
    @denoxi 10 місяців тому +1

    Привет! Огромное спасибо за видео! А можно объединить многопоточность и Asyncio? Было бы здорово посмотреть твое видео с этим примером)

    • @PythonRussian
      @PythonRussian  10 місяців тому +1

      идея хорошая, надо подумать - сделать ли это сразу или после процессов сразу и про потоки и про процессы.

  • @alexgreen984
    @alexgreen984 9 місяців тому +1

    Спасибо, полезно

  • @Tonyjusttony
    @Tonyjusttony 9 місяців тому

    Лучший! Спасибо.

  • @普京的手机
    @普京的手机 9 місяців тому +2

    А будет такой же прекрасный урок по multiprocessing?

    • @PythonRussian
      @PythonRussian  9 місяців тому +1

      будет, но попозже и не уверен, что прекрасный)

  • @FarofWell
    @FarofWell 10 місяців тому +2

    наконец то асинхронка

  • @lifestyletv139
    @lifestyletv139 10 місяців тому +2

    Красава бро

  • @benben-fz2es
    @benben-fz2es 10 місяців тому

    один момент не уяснил - если авейтить простой вызов (например, несинхронный реквест), оно ждет?
    или ей и увнутре тоже надо помечаться = иметь переписанную под асинкайо библиотеку. попробую вечером покатать. например - поставить обычный sleep.
    засада если нет - если наследовал классы из стандартных не-асинхронных, придется слегка переписывать, рефактора может и не хватить.

    • @PythonRussian
      @PythonRussian  10 місяців тому +1

      я большую часть вопроса вообще не понял, но ты не можешь авейтить что попало, только Awaitable объекты то есть корутины, таски и так далее, несинхронный реквест не будет авейтится -упадет ошибка.

    • @benben-fz2es
      @benben-fz2es 10 місяців тому

      @@PythonRussian именно это я и спрашивал. Корутины, использующие неасинкио айо запросы. Ошибка. Понял. Значит, приватное айо через потоки.

    • @benben-fz2es
      @benben-fz2es 10 місяців тому

      Поправь, правильно ли я понял.
      если очень грубо: в отличие от многопоточности, где у тебя в питоне есть свой скедулер раздавать кванты времени любому типу кода, используем почти прямые систем коллы, и полагаемся на операционку для таск свитча. То есть если авейтить *свой* код, а не неприкрытые систем коллы из асинкио, то некому скедулить, потому что операционка не умеет свитчить арбитрарные/приватные куски кода. Логично.
      Но, конечно, костылик такой себе - убрать свой скедулер в пользу операционки *через ТАКОЕ*. Выигрыш - в убирании оверхеда своего скедулера, проигрыш - сужение применения: только системколлы. Да и синтаксис немного напрягает: киворды - доступны, а механика за ними - только после импорта асинкио.

    • @benben-fz2es
      @benben-fz2es 10 місяців тому

      И еще раз спасибо. Твои видео - драгоценны!

  • @rayrayray4653
    @rayrayray4653 10 місяців тому +1

    Четко!!!

  • @quasar-lv6pp
    @quasar-lv6pp 10 місяців тому

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

    • @PythonRussian
      @PythonRussian  10 місяців тому

      у меня на видео то времени нет почти, практика - это сложно, мало кому интересно будет, все же со своими желаниями и планами.

  • @VaGroz
    @VaGroz 4 місяці тому

    Не пойму, в питоне изобрели монаду?

  • @EshkaG
    @EshkaG 10 місяців тому

    Охх какая тема.. Автор бросил вызов решив взяться за Asyncio на своём канале с его стилем объяснения..но я посмотрю и запишу всё!

  • @blackark11
    @blackark11 8 місяців тому +1

    Спасибо

  • @pLop6912
    @pLop6912 7 місяців тому +1

    Огромное спасибо, появилось понимае как все это работает, но все же вопрос задам, есть библиотека PyQt5 она единственная выполняет нужное мне создание интерфейса ни одна другая его повторить не смогла но она блокирует карутины, можно ли это ка кто обойти и запустить окно без блокировки остальных карутин?

    • @PythonRussian
      @PythonRussian  7 місяців тому

      я не знаю конкретно эту библиотеку, но точно знаю что все графические либы имеют встроенный, верный механизм работы с фоновыми задачами, вот это тебе надо поискать и изучить. Скорее всего это отдельные потоки, но может быть и асинхронка, просто надо посмотреть как сами создатели рекомендуют это делать. Чтобы самому велосипеды не придумывать

    • @pLop6912
      @pLop6912 7 місяців тому

      @@PythonRussian Спасибо, за объяснение буду искать, жаль идея в том что граф интерфейс побочная история проекта скажем так важный но не обязательный модуль, и в таком ключе делать его основой с фоновыми задачами не сильно подходит.

    • @shizagonia
      @shizagonia Місяць тому

      @@pLop6912 В qt все подобные задачи через воркеры QThread решаются

  • @ВикторЮпин
    @ВикторЮпин 10 місяців тому +1

    мужик!!!

  • @Sizt
    @Sizt 8 місяців тому

    Не очень понятно, как получить выигрыш за счет asyncio, используя только стандартную библиотеку.
    На 0:38 обещали рассказать принцип работы, а он так и не был объяснен в видео :( Очень хотелось бы подобный пример.

    • @Andrey_AKA_Zumz
      @Andrey_AKA_Zumz 8 місяців тому

      Так в примерах и используется стандартная библиотека.
      Пересмотрите первую половину.
      В стандартной библиотеке есть синхронные функции и асинхронные. Как пример, пакеты asyncio, aiohttp. В корутинах надо с await использовать асинхронные.

    • @Sizt
      @Sizt 8 місяців тому

      aiohttp не стандартная.

  • @kishiva4965
    @kishiva4965 7 місяців тому

    Крутое видео, спасибо!
    Правильно ли я понимаю, что в асинке не получится перемешать синхронные функции и асинхронные? Например у меня есть 6 функций обращений к разным внешним ресурсам по апи, но вызываются они в разное время синхронными функциями, получается чтобы воспользоваться благами асинхронности, мне придётся вызывать все асинхронные функции обращений одной асинхронной main функцией разом в одном моменте, а уже потом проводить все остальные синхронные манипуляции?

    • @PythonRussian
      @PythonRussian  7 місяців тому

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

    • @dmtt1654
      @dmtt1654 2 місяці тому

      ​@@PythonRussianнемного не ясно, если в корутине написать await response=request.get(...) то разве она не передаст управление следующей корутине? То есть реквест синхронный но в том и суть что пока ждём ответ, то выполняем что-то ещё. Почему вы говорите что нельзя использовать синхронные библиотеки неясно.

  • @stevem4806
    @stevem4806 10 місяців тому

    Здравствуйте, спасибо за видео! Только я не понял как правильно await‘ы ставить в асинхронных функциях?

    • @PythonRussian
      @PythonRussian  10 місяців тому

      мы их ставим там, где нам нужно дождаться результата какой-либо корутины

    • @stevem4806
      @stevem4806 10 місяців тому

      @@PythonRussian понял вас, спасибо!

  • @hdhdjdjdjjd1263
    @hdhdjdjdjjd1263 Місяць тому

    Привет, асинхронность можно считать синонимом конкурентности?

    • @PythonRussian
      @PythonRussian  Місяць тому +1

      я вот сейчас задумался и особо сильных возражений не имею

  • @user-buser_eto_ja
    @user-buser_eto_ja 10 місяців тому

    СПАСИБОООООО!!!

  • @stspartak
    @stspartak 10 місяців тому

    The BEST!

  • @amalshakov
    @amalshakov 7 місяців тому

    Я новичок в АП. Объясните, вы говорите, что await - это явный флаг, мол я потуплю, а ты иди работай дальше пока. Окей, тогда с этой логикой, если бы было просто sleep(3), понятно, интерпретатор ждет. и с вашей же логикой, если добавить await sleep(3), то должно все получится, ну мы же сказали интерпретатору, что эта функция кортуина (async), в ней указали await sleep(3). Почему это не работает? Я не понимаю. Ps: ааа...досмотрел до конца вроде понял, это типа все блокирующие опрерации - просто sleep, просто родной request (у них под капотом нет await), а asyncio.sleep и aiohttp у них под капотом есть тот самый await. Хотя не до конца все это мне понятно). Ну с requests/aiohttp более менее понятно. Но со sleep нет.

  • @АлмазЗияпов
    @АлмазЗияпов 6 місяців тому

    Не совсем понял, как при ручном создании задач выбрать ту которой нужно приписать await.
    Если я у себя делаю приписку самой короткой задаче, то скрипт завершается как только выполнится эта самая короткая задача, не дожидаясь остальных.
    Т.е. как будто нужно приписывать await самой долгой задаче. Но я не знаю заранее, какая из них займет больше всего времени.
    Объясните, пожалуйста, логику необходимых здесь рассуждений.

    • @fr1ezz522
      @fr1ezz522 4 місяці тому

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

    • @n0rmaLman
      @n0rmaLman 4 місяці тому

      Я тоже не понял почему await поставили только у одной задачи. Может правильно будет у всех задач его проставить. Мы ведь заранее можем и не знать какая из них будет выполнена последней.

  • @PNirtep
    @PNirtep 4 місяці тому

    Не очень понял момента с засыпанием 3 функций на 1,2,3 секунды. Вот 1 функция уснула на 1 сек. Цикл событий в этот момент запустил 2 функцию и остановил ее на 2 секунды. Почему в примере следом запустилась 3 функция, ведь у 1 функции время сна закончилось и по идее она должна была с паузы уйти и выполниться

    • @PythonRussian
      @PythonRussian  4 місяці тому

      а почему ты думаешь что переключение на 2 функцию и отправка ее спать заняло ровно 1 секунду? это очень быстро происходит, первая функция еще свое не отоспала, потому и не включилась, но мысль верная, если бы ее время подошло то она бы проснулась.

  • @ИннаЛиксакова-о4н
    @ИннаЛиксакова-о4н 8 місяців тому

    так и не поняла, почему если после await asyncio.sleep(2) я напишу следующей строчкой input(), то программа просто завершится без запроса ввода ?

    • @Andrey_AKA_Zumz
      @Andrey_AKA_Zumz 8 місяців тому

      Потому что поток выполнения на await передаеься следующей корутине в цикле событий.
      Если в очереди нет других корутин, то main завершается, если вы в main не дождались выполнения корутины.

  • @vandriichuk
    @vandriichuk 6 місяців тому

    Круто

  • @DeliriumOFF
    @DeliriumOFF 10 місяців тому

    c файлами тоже есть асинхронная работа?

    • @PythonRussian
      @PythonRussian  10 місяців тому

      на самом деле там есть сложности, по разному реализовано на разных ОС, потому скорее с файлами придется работать используя потоки, асинкио умеет запускать в отдельном потоку блокирующую задачу не мешая текущему циклу событий

    • @non5309
      @non5309 10 місяців тому

      есть

  • @ОлегДорожкин-я1е
    @ОлегДорожкин-я1е 10 місяців тому +1

    ещё бы разбор асинхронщины в django 5

    • @PythonRussian
      @PythonRussian  10 місяців тому

      увы, этого точно не будет, я не использую джанго

  • @donatelmrlybarskiy6171
    @donatelmrlybarskiy6171 7 місяців тому

    Пушка брат

  • @paulkarkarin466
    @paulkarkarin466 10 місяців тому

    Можно было Semaphore упомянуть. Чтобы люди понимали, что корутина не резиновая. А многие API вообще не любят когда их реквестами досят по 100 запросов в секунду. Вернут 500 ошибку и будут сидеть. Вообще, скорее это и есть слабое место: ограничение серверов на забор/вставку данных.
    Хотел спросить про мультитрединг+асинхронность: можно ли их как-то совместить, чтобы по максимуму использовать возможности железа (в условиях питона)? На самом деле это просто праздный вопрос из любопытства, учитывая ограничения, о которых я написал в начале.

    • @sio8730
      @sio8730 10 місяців тому +1

      мультитрединг+асинхронность не даст по максимуму задействовать железо (ядра процессора), ответ в документации CPython (реализации интерпретатора на Си), если кратко то виной этому GIL.
      А вот связка мультипроцессинг+асинхронность позволит при грамотном построении программы очень неплохо нагрузить железо

    • @PythonRussian
      @PythonRussian  10 місяців тому +1

      чтобы железо по максимуму в дело пустить, это надо другой язык =) вот с питона 13 говорят ГИЛ уберут(опционально), соответственно даже простой многопоточки должно хватать, но это надо будет смотреть как оно в реале будет и я сомневаюсь что прямо все ядра процессора задействует.

  • @sergeyvereshaghin2330
    @sergeyvereshaghin2330 10 місяців тому +1

    Прочитал сначала как: разбор arduino)) думаю, что за приколы 😂

  • @HanzoEsenov
    @HanzoEsenov 2 місяці тому

    pochemu my napisali await asyncio.create_task(three()) a ne prosto asyncio.create_task(three())

    • @HanzoEsenov
      @HanzoEsenov 2 місяці тому

      Blin ya nashyol etot otvet na 25:28 Drugiye progery ne skazali by Spasibo Broooo

  • @gunlinux
    @gunlinux 6 місяців тому

    Урок отличный, но блин почему пограммисты получают 300к в секунду, но не могут микрофон настроить. И вместо микрофона банка от прингс. Шум в аудасити убирается в два клика.

    • @PythonRussian
      @PythonRussian  6 місяців тому

      так уж в жизни устроено, выбирать надо что-то одно - или разбираться в аудасити\микрофонах или много получать. =)

    • @gunlinux
      @gunlinux 6 місяців тому

      @@PythonRussian если бы проблема не решалась за 5 минутным видосом, на котором школьник объясняет что да как. Я бы не вайнил. получаю 300к в секунду и умею настраивать микро.

  • @IgorChistruga
    @IgorChistruga 3 місяці тому

    Пресное видео, замечательная передача материала.... но есть же perf_counter из time для более точного вычисления времени выполнения...

  • @TrealDry
    @TrealDry 6 місяців тому

    Материал объяснил хорошо, но воды много. Слишком много повторений.

  • @tenebris8800
    @tenebris8800 9 місяців тому

    Кто знает как два лайка поставить???

  • @IvanSergienko-b6w
    @IvanSergienko-b6w 2 дні тому

    Посоветуйте хорошие книги на русском языке

    • @PythonRussian
      @PythonRussian  2 дні тому

      так под видео книга рекомендуется

    • @IvanSergienko-b6w
      @IvanSergienko-b6w День тому

      @PythonRussian спасибо...взял на заметку...а может ещё какую нибудь посоветуете... хороших книг много не бывает)

  • @crazzy6903
    @crazzy6903 7 місяців тому

    Такое ощущение как будто рассказывается для дегенератов. Повторяется что то очевидно по сто раз. Терминология по типу замораживатель времени вообще меня убила Спасибо!

    • @PythonRussian
      @PythonRussian  7 місяців тому

      а главное -это работает )))

  • @Romanrasdfasdf
    @Romanrasdfasdf 2 місяці тому

    - "умирает" из-за одного блокирующего вызова (!)
    Не совсем так. Только из-за ДЛИТЕЛЬНОГО блокирующего вызова. Короткие делать в асинхронном коде - никаких проблем. Как, например, писать логи модулем logging из стандартной библиотеки.

  • @ЕвгенийЮрченко-с1ф
    @ЕвгенийЮрченко-с1ф 8 місяців тому

    Очень плохое объяснение асинхронности. Куча воды, мутные термины... Советую поискать другие источники, их полно!

  • @eugenybobylev5438
    @eugenybobylev5438 7 місяців тому +1

    Сколько людей, только мнений. Мне не зашло, очень мутное объяснение

    • @PythonRussian
      @PythonRussian  7 місяців тому

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

  • @jutich-d5h
    @jutich-d5h 20 днів тому

    Слишком много слов, усложняет пониманимание информации, на х2 засыпаю

  • @Nicktimes
    @Nicktimes 10 місяців тому +1

    Вопрос в момент усыпления корутины,когда ивент отлажывает эту корутину в список,и переключается на другую,Запросы в бд или на сайт выполняется уже?раз Ивент понял что в этой корутине пришел ответ от Бд либо от сайта,чутка поясните,эти запросы и ответы приходят в момент когда корутину убрали спать?

    • @PythonRussian
      @PythonRussian  10 місяців тому

      я просто не хотел усложнять объяснение, но вопрос верный задаете. По сути в момент авейта в ивент луп на самый верх кладется как раз корутина которую ждем(например запрос к сайту) она сразу начинает выполняться. И уже она (обычно это какая то библиотека типа аиохттп под капотом) делает запрос и так как ответ нужно ждать тоже объявляет авейт до момента прихода ответа. От нас это обычно скрыто особенностями реализации библиотек, потому что мы пользователи этих библиотек и нам не очень важно что конкретно они делают, главное понимать как с ними работать (авейты и т.п.). Но если вы сами хотите писать такие библиотеки то тут конечно без погружение в детали асинкио не обойтись.

    • @Nicktimes
      @Nicktimes 10 місяців тому

      @@PythonRussian спасибо за хорошее разьяснение...

  • @Hi-gjgruncdun
    @Hi-gjgruncdun 8 місяців тому

    Лайк подписка, очень доходчиво, спасибо

  • @photo_graf_khv
    @photo_graf_khv 8 місяців тому +1

    Отличное объяснение! Благодарю!