Video není dostupné.
Omlouváme se.

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

Sdílet
Vložit
  • čas přidán 5. 09. 2023
  • Как и обещал:
    var sleepTaskArray = [UInt32]()
    sleepTaskArray.append(3)
    sleepTaskArray.append(7)
    sleepTaskArray.append(15)
    let semaphote = DispatchSemaphore(value: 1)
    let queue = DispatchQueue(label: "queue", attributes: .concurrent)
    for taskItem in sleepTaskArray {
    serialQueue.async {
    for i in 1...taskItem{
    sleep(1)
    print("TaskItem: \(taskItem), i: \(i)")
    }
    semaphote.signal()
    }
    semaphote.wait()
    }

Komentáře • 32

  • @user-ov5ns3uq6t
    @user-ov5ns3uq6t Před 9 měsíci +3

    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  Před 9 měsíci

      Лучший, бро)

  • @silbenking
    @silbenking Před 9 měsíci +8

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

  • @Le_schiffer
    @Le_schiffer Před 11 měsíci +7

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

    • @fonzyara
      @fonzyara  Před 11 měsíci +2

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

    • @Le_schiffer
      @Le_schiffer Před 11 měsíci +1

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

    • @glebnikitenko6971
      @glebnikitenko6971 Před 11 měsíci +1

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

  • @artyom5602
    @artyom5602 Před 6 měsíci +3

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

  • @Arti1k_ios
    @Arti1k_ios Před měsícem

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

  • @grishanchannel6813
    @grishanchannel6813 Před 11 měsíci +6

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

    • @user-jz2jo3vd4d
      @user-jz2jo3vd4d Před 9 měsíci

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

    • @dobrysiabar8791
      @dobrysiabar8791 Před 9 měsíci +1

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

  • @user-qr1ko7ol6g
    @user-qr1ko7ol6g Před 11 měsíci

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

  • @MaxBaritone
    @MaxBaritone Před 8 měsíci +1

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

    • @user-qb1xy3jq5x
      @user-qb1xy3jq5x Před 7 měsíci

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

  • @Deidg
    @Deidg Před 8 měsíci

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

  • @alexcher7741
    @alexcher7741 Před 10 měsíci

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

  • @Andrew-7324
    @Andrew-7324 Před 9 měsíci

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

  • @user-ii7mw4fy4t
    @user-ii7mw4fy4t Před 4 měsíci

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

  • @m.d.2029
    @m.d.2029 Před 4 měsíci +1

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

  • @damiryumaguzhin
    @damiryumaguzhin Před 10 měsíci

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

  • @Andrew-7324
    @Andrew-7324 Před 9 měsíci +2

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

    • @m.d.2029
      @m.d.2029 Před 4 měsíci

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

    • @6-217
      @6-217 Před 2 měsíci

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

    • @6-217
      @6-217 Před 2 měsíci

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

  • @pickleteach1920
    @pickleteach1920 Před 11 měsíci +1

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

  • @Extremelool
    @Extremelool Před 10 měsíci

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

  • @alexcher7741
    @alexcher7741 Před 9 měsíci +1

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

  • @petrun
    @petrun Před 9 měsíci

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

  • @TheScrinn
    @TheScrinn Před 9 měsíci

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

  • @Medovar
    @Medovar Před 8 měsíci

    Кто шуршит