Многопоточность в iOS. Part I - Разбор вопросов с IOS собеседований

Поделиться
HTML-код
  • Опубликовано: 27 ноя 2024

Комментарии • 33

  • @ВадимВоронков-д9ы
    @ВадимВоронков-д9ы Год назад +4

    1:22 Асинхронность vs Многопоточность
    2:35 Serial Concurrent
    3:37 сколько потоков могут иметь serial и concurrent очереди
    4:40 семафор и Mutex
    9:06 что такое атомарность
    9:50 barrierTask
    16:20 Есть ли способ отменить переданный на выполнение блок в GCD
    17:35 Что такое QoS
    19:15 Потокобезопасны ли классы и структуры
    20:30 Что такое тред пул
    22:00 Потокобезопасно ли чтение или доступ к переменным класса
    22:46 Почему serial быстрее concurrent
    23:45 Какое количество потоков может максимально выполняться в единицу времени
    24:16 Когда DispatchQueue создаст новый поток?
    24:45 Правда ли что у каждого потока свой RunLoop?
    25:30 Можно ли работать с массивом read/write внутри dispatch async

    • @fonzyara
      @fonzyara  Год назад

      Лучший, бро)

  • @Le_schiffer
    @Le_schiffer Год назад +7

    Прям ждал следующий видос, а тут ещё и по такой нужной мне сейчас теме. Автор красавчик

    • @fonzyara
      @fonzyara  Год назад +2

      Спасибо!) на этой неделе будет второй выпуск по поточке!

    • @Le_schiffer
      @Le_schiffer Год назад +1

      @@fonzyara жду. По ARC готовился в том числе и по твоему видео, по многопоточке тоже буду

    • @glebnikitenko6971
      @glebnikitenko6971 Год назад +1

      @@fonzyaraочень ждём следующий выпуск по многопоточке👍

    • @AnnaRuslanovna-d1p
      @AnnaRuslanovna-d1p 7 дней назад

      @@fonzyara я так понимаю вторую часть снесли?

  • @silbenking
    @silbenking Год назад +8

    Очень круто и полезно, не забрасывай канал, у тебя хорошо и просто получается объяснять - редко встретишь сейчас такие каналы

  • @artyom5602
    @artyom5602 9 месяцев назад +4

    3:50 - Serial НЕ гарантирует, что все задачи будут на одном потоке

  • @АлександрБулычев-у6р

    Спасибо за разбор вопросов! Как и все жду следующее видео

  • @Arti1k_ios
    @Arti1k_ios 4 месяца назад +1

    6:59 (с код в описании) - не верный:
    1. имеется синтактическая ошибка, вместо serialQueue нужно queue
    2. semaphore.wait() вызывается не в правильном месте, нужно до асинхронного блока кода (до queue.async {)

  • @grishanchannel6813
    @grishanchannel6813 Год назад +7

    Отличный видикс для новичков. Только звук бы погромче выкрутить

    • @МаринаЛеонова-д5й
      @МаринаЛеонова-д5й Год назад

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

    • @gomayata-f2n
      @gomayata-f2n Год назад +1

      @@МаринаЛеонова-д5й да, так и есть. Был бы я собеседующим, я бы многое не принял как за полный ответ и много вопросов задал бы дополнительно.

  • @Andrew-7324
    @Andrew-7324 Год назад

    24:58 - не у каждого потока всегда есть ранлуп, а только у главного, для остальных нужно создавать его и запускать самостоятельно

  • @alexcher7741
    @alexcher7741 Год назад

    Хорошие видео, спасибо. Хотелось бы более подробной информации конечно ) Copy on write sweezling и т д. Но спасибо огромное автору

  • @m.d.2029
    @m.d.2029 7 месяцев назад +1

    По первом вопросу НЕВЕРНО! Асинхронные задачи могут выполняться как в рамках одного потока, так и в рамках нескольких потоков - т.е. многопоточный асинхронный код.

  • @MaxBaritone
    @MaxBaritone 11 месяцев назад +1

    Только асинхронность - это характеристика вызова (неблокирующий) с возвратом управления вызывающему потоку мгновенно. А многопоточность - распределение работы (процессов) по потокам. Этот странный вопрос в духе сравнения теплого с мягким иногда встречается, увы ))

    • @Anton-r9o
      @Anton-r9o 11 месяцев назад

      Наверное самое простое объяснение которое видел)

  • @Deidg
    @Deidg 11 месяцев назад

    Спасибо за очередную интересную серию.
    Желательно сделать звук погромче.

  • @pickleteach1920
    @pickleteach1920 Год назад +1

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

  • @damiryumaguzhin
    @damiryumaguzhin Год назад

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

  • @Extremelool
    @Extremelool Год назад

    Из коробки runloop ведь есть только у main потока, для всех остальных надо реализовывать самому

  • @alexcher7741
    @alexcher7741 Год назад +1

    Жаль что перестал выкладывать видосики

  • @petrun
    @petrun Год назад

    Бро, когда продолжение? Очень надо.

  • @Andrew-7324
    @Andrew-7324 Год назад +3

    24:12 а разве 64 бита как-то связано с количеством потоков? 64 бита определяют размер указателя и количество памяти считываемое за один цикл обращения к памяти

    • @m.d.2029
      @m.d.2029 7 месяцев назад

      Все верно говоришь!

    • @6-217
      @6-217 6 месяцев назад

      Прав и это не фактор, говорящий напрямую о кол-ве потоков, но косвено он тоже влияет на их кол-во

    • @6-217
      @6-217 6 месяцев назад

      сказать сколько точно потоков у системы с лету сложно. Думаю у самого тред пула есть как определенно созданное кол-во так и возможность раширяться и thread explosiion по хорошему добиться сложно, в штатном режиме

  • @abd3d2fKm-s
    @abd3d2fKm-s 8 месяцев назад

    а зачем отпускать мьютекс в последнем примере в блоке defer - разве просто вызов unlock() после append не так же отработает?

  • @TheScrinn
    @TheScrinn Год назад

    Майн респектабль

  • @Medovar
    @Medovar Год назад

    Кто шуршит