Назад к вопросам
IT One
Middle+
2
const obj = [{ value: 1, elems: [ { value: 2, elems: [ { value: 3 }, { value: 6 }, ... ] }, { value: 4, elems: [ { value: 5, elems: [ { value: 6 }, ... ]} ] } ] }] ------------- setTimeout(() => { console.log(1); }, 0); const p = new Promise(resolve => { console.log(2); resolve(); }); p.then(() => { console.log(3) }).then(() => { console.log(4); }); console.log(5);
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Рассмотрим порядок вывода в консоль:
setTimeout(() => {
console.log(1);
}, 0);
const p = new Promise(resolve => {
console.log(2);
resolve();
});
p.then(() => { console.log(3) }).then(() => { console.log(4); });
console.log(5);
Пояснение:
setTimeoutставит колбэк в очередь макротасков с задержкой 0.- При создании промиса сразу выполняется его исполнитель, поэтому
console.log(2)выводится сразу. p.thenдобавляет колбэки в очередь микротасков.console.log(5)выполняется синхронно после создания промиса.
Порядок вывода:
- 2 (сразу при создании промиса)
- 5 (после промиса, синхронно)
- 3 (микротаск из
then) - 4 (следующий микротаск из цепочки
then) - 1 (макротаск из
setTimeout)
Итог:
2
5
3
4
1