JavaScript通过事件循环实现异步,先执行同步代码,再处理微任务队列,最后执行宏任务;例如1→4→3→2,因微任务优先于宏任务执行。

JavaScript 是单线程语言,意味着同一时间只能执行一个任务。为了在不阻塞主线程的情况下处理异步操作(如网络请求、定时器、用户交互等),JavaScript 设计了一套独特的并发模型,这套模型基于事件循环(Event Loop)、调用栈(Call Stack)、任务队列(Task Queue)和微任务队列(Microtask Queue)协同工作。
JavaScript 的代码执行依赖于调用栈,它是一个后进先出(LIFO)的数据结构,用于追踪函数的执行。每当函数被调用,就会被推入栈中;函数执行完毕后,从栈中弹出。
由于 JavaScript 是单线程的,所有同步代码会按顺序在调用栈中执行。但遇到异步操作时,比如 setTimeout、fetch 或 Promise,它们不会立即执行回调,而是交由浏览器的 Web API 处理,完成后将回调放入相应的任务队列。
JavaScript 中的异步任务分为两类:宏任务(Macro Task)和微任务(Micro Task)。
立即学习“Java免费学习笔记(深入)”;
宏任务包括:
微任务包括:
事件循环的执行规则是:
以下代码可以帮助理解执行顺序:
console.log('1'); setTimeout(() => { console.log('2'); }, 0); Promise.resolve().then(() => { console.log('3'); }); console.log('4');输出结果为:1 → 4 → 3 → 2
原因:
JavaScript 虽然是单线程,但通过事件循环实现了“看似并发”的效果。
基本上就这些,理解清楚调用栈、任务队列和事件循环的协作方式,就能掌握 JavaScript 的执行机制。不复杂但容易忽略细节。
以上就是JavaScript并发模型_javascript执行机制的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号