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&7apparaissent immédiatement, car les appels simplesconsole.logn’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&5apparaissent, 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.