Quelle sera la sortie de ce code?
importance: 5
console.log(1);
setTimeout(() => console.log(2));
Promise.resolve().then(() => console.log(3));
Promise.resolve().then(() => setTimeout(() => console.log(4)));
Promise.resolve().then(() => console.log(5));
setTimeout(() => console.log(6));
console.log(7);
La sortie console est : 1 7 3 5 2 6 4.
La tâche est assez simple, nous avons juste besoin de savoir comment fonctionnent les files d’attente pour microtâches et macrotâches.
Voyons ce qui se passe, étape par étape.
console.log(1);
// La première ligne s'exécute immédiatement, elle sort `1`.
// Les files d'attente Macrotask et Microtask sont vides, pour l'instant.
setTimeout(() => console.log(2));
// `setTimeout` ajoute la callback à la file d'attente macrotask.
// - la file d'attente macrotask contient:
// `console.log(2)`
Promise.resolve().then(() => console.log(3));
// La callback est ajoutée à la file d'attente des microtâches.
// - contenu de la file d'attente des microtâches:
// `console.log(3)`
Promise.resolve().then(() => setTimeout(() => console.log(4)));
// La callback avec `setTimeout (...4) `est ajoutée aux microtâche
// - contenu de la file d'attente des microtâches:
// `console.log(3); setTimeout(...4)`
Promise.resolve().then(() => console.log(5));
// La callback est ajoutée à la file d'attente des microtâches
// - contenu de la file d'attente des microtâches:
// `console.log(3); setTimeout(...4); console.log(5)`
setTimeout(() => console.log(6));
// `setTimeout` ajoute la callback aux macrotasks
// - contenu de la file d'attente macrotask:
// `console.log(2); console.log(6)`
console.log(7);
// Affiche 7 immédiatement.
Pour résumer,
- Les numéros
1
&7
apparaissent immédiatement, car les appels simplesconsole.log
n’utilisent aucune file d’attente. - Ensuite, une fois le flux de code principal terminé, la file d’attente des microtâches s’exécute.
– Il possède les commandes:
console.log(3); setTimeout(...4); console.log(5)
. – Les nombres3
&5
apparaissent, tandis quesetTimeout(() => console.log(4))
ajoute l’appelconsole.log(4)
à la fin de la file d’attente macrotask. – La file d’attente macrotask est maintenant:console.log(2); console.log(6); console.log(4)
. - Une fois la file d’attente des microtâches vide, la file d’attente des macrotasques s’exécute. Il sort
2
,6
,4
.
Au final, nous avons la sortie: 1 7 3 5 2 6 4
.