Тёмный

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

Vladimir Alecseev. In IOS dev
Подписаться 1,3 тыс.
Просмотров 6 тыс.
50% 1

Как и обещал:
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()
}

Опубликовано:

 

1 окт 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 32   
@ВадимВоронков-д9ы
@ВадимВоронков-д9ы 11 месяцев назад
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 11 месяцев назад
Лучший, бро)
@artyom5602
@artyom5602 8 месяцев назад
3:50 - Serial НЕ гарантирует, что все задачи будут на одном потоке
@silbenking
@silbenking 11 месяцев назад
Очень круто и полезно, не забрасывай канал, у тебя хорошо и просто получается объяснять - редко встретишь сейчас такие каналы
@grishanchannel6813
@grishanchannel6813 Год назад
Отличный видикс для новичков. Только звук бы погромче выкрутить
@МаринаЛеонова-д5й
@МаринаЛеонова-д5й 11 месяцев назад
Джун для джунов - интересный формат). Но... много не точностей и ляпов((, имейте ввиду новички переучиваться потом будет сложнее, чем сразу нормально учится на офф. документации.
@dobrysiabar8791
@dobrysiabar8791 11 месяцев назад
@@МаринаЛеонова-д5й да, так и есть. Был бы я собеседующим, я бы многое не принял как за полный ответ и много вопросов задал бы дополнительно.
@Le_schiffer
@Le_schiffer Год назад
Прям ждал следующий видос, а тут ещё и по такой нужной мне сейчас теме. Автор красавчик
@fonzyara
@fonzyara Год назад
Спасибо!) на этой неделе будет второй выпуск по поточке!
@Le_schiffer
@Le_schiffer Год назад
@@fonzyara жду. По ARC готовился в том числе и по твоему видео, по многопоточке тоже буду
@glebnikitenko6971
@glebnikitenko6971 Год назад
@@fonzyaraочень ждём следующий выпуск по многопоточке👍
@Arti1k_ios
@Arti1k_ios 2 месяца назад
6:59 (с код в описании) - не верный: 1. имеется синтактическая ошибка, вместо serialQueue нужно queue 2. semaphore.wait() вызывается не в правильном месте, нужно до асинхронного блока кода (до queue.async {)
@m.d.2029
@m.d.2029 5 месяцев назад
По первом вопросу НЕВЕРНО! Асинхронные задачи могут выполняться как в рамках одного потока, так и в рамках нескольких потоков - т.е. многопоточный асинхронный код.
@MaxBaritone
@MaxBaritone 10 месяцев назад
Только асинхронность - это характеристика вызова (неблокирующий) с возвратом управления вызывающему потоку мгновенно. А многопоточность - распределение работы (процессов) по потокам. Этот странный вопрос в духе сравнения теплого с мягким иногда встречается, увы ))
@Anton-r9o
@Anton-r9o 9 месяцев назад
Наверное самое простое объяснение которое видел)
@alexcher7741
@alexcher7741 10 месяцев назад
Жаль что перестал выкладывать видосики
@Andrew-7324
@Andrew-7324 11 месяцев назад
24:12 а разве 64 бита как-то связано с количеством потоков? 64 бита определяют размер указателя и количество памяти считываемое за один цикл обращения к памяти
@m.d.2029
@m.d.2029 5 месяцев назад
Все верно говоришь!
@6-217
@6-217 4 месяца назад
Прав и это не фактор, говорящий напрямую о кол-ве потоков, но косвено он тоже влияет на их кол-во
@6-217
@6-217 4 месяца назад
сказать сколько точно потоков у системы с лету сложно. Думаю у самого тред пула есть как определенно созданное кол-во так и возможность раширяться и thread explosiion по хорошему добиться сложно, в штатном режиме
@abd3d2fKm-s
@abd3d2fKm-s 6 месяцев назад
а зачем отпускать мьютекс в последнем примере в блоке defer - разве просто вызов unlock() после append не так же отработает?
@pickleteach1920
@pickleteach1920 Год назад
Большое спасибо!
@Extremelool
@Extremelool Год назад
Из коробки runloop ведь есть только у main потока, для всех остальных надо реализовывать самому
@Deidg
@Deidg 10 месяцев назад
Спасибо за очередную интересную серию. Желательно сделать звук погромче.
@damiryumaguzhin
@damiryumaguzhin Год назад
Спасибо за видос! Только есть пару моментов. Очень тихий звук и слышно как ты делаешь каждое движение мышкой.
@petrun
@petrun 10 месяцев назад
Бро, когда продолжение? Очень надо.
@alexcher7741
@alexcher7741 Год назад
Хорошие видео, спасибо. Хотелось бы более подробной информации конечно ) Copy on write sweezling и т д. Но спасибо огромное автору
@Andrew-7324
@Andrew-7324 11 месяцев назад
24:58 - не у каждого потока всегда есть ранлуп, а только у главного, для остальных нужно создавать его и запускать самостоятельно
@АлександрБулычев-у6р
Спасибо за разбор вопросов! Как и все жду следующее видео
@Medovar
@Medovar 10 месяцев назад
Кто шуршит
@TheScrinn
@TheScrinn 10 месяцев назад
Майн респектабль
Далее
The Value of Source Code
17:46
Просмотров 40 тыс.