JavaScript是一门单线程语言,即在任何一个时间点只能执行一个任务,这是因为JavaScript的执行机制是基于事件循环(Event Loop)的。事件循环机制就是循环地去检查消息队列中是否有任务需要执行,如果有则取出并执行,否则就继续等待新的任务加入队列。
具体来说,JavaScript代码的执行分为两个阶段:
- 解析代码阶段:在这个阶段,JavaScript引擎会对代码进行词法分析和语法分析,构建抽象语法树(AST),并生成执行上下文(Execution
Context)对象。 - 执行代码阶段:在这个阶段,JavaScript引擎会按照语法树和执行上下文对象中保存的变量、函数等信息来执行代码。
在执行代码阶段中,JavaScript引擎会将任务分为同步任务和异步任务。同步任务会直接进入调用栈(Call Stack)中依次执行,而异步任务则会被放入消息队列(Message Queue)中等待执行。
当调用栈中的任务全部执行完毕时,JavaScript引擎会从消息队列中取出一个异步任务并将其放入调用栈中执行,直到调用栈为空或者没有异步任务为止。这个过程就是JavaScript的事件循环。
下面是一个示例代码,演示了JavaScript的执行机制:
console.log('start');
setTimeout(() => {
console.log('setTimeout');
}, 0);
Promise.resolve().then(() => {
console.log('Promise');
});
console.log('end');
这段代码会先输出start,然后输出end,接着在下一轮事件循环中输出Promise和setTimeout。这是因为在第一轮事件循环中,先执行了同步任务中的console.log(‘end’),然后执行异步任务中的Promise.resolve().then(() => {console.log(‘Promise’);});,最后取出setTimeout任务并放入消息队列中。在第二轮事件循环中,先执行异步任务中的Promise,然后取出setTimeout任务并执行。