JavaScript的执行模型是如何在单线程中处理异步任务和事件循环的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1284个文字,预计阅读时间需要6分钟。
JavaScript执行模型+引言+JavaScript是一个单线程(Single-threaded)的异步(Asynchronous)、非阻塞(Non-blocking)并发(Concurrent)语言,这些语言效果通过调用栈(Call Stack)和事件循环(Event Loop)实现。
JavaScript执行模型
引言
JavaScript是一个单线程(Single-threaded)异步(Asynchronous)非阻塞(Non-blocking)并发(Concurrent)语言,这些语言效果通过一个调用栈(Call Stack)、一个事件循环(Event Loop)、一个回调队列(Callback Queue)有些时候也叫任务队列(Task Queue)与跟运行环境相关的API组成。
概念
调用栈 Call Stack
调用栈是一个LIFO后进先出数据结构的函数运行栈,它内部的数据结构为函数帧。当在JavaScript中调用一个函数时,它将被压入栈中,当这个函数内部还有另一个函数被调用时,另一个函数将会被压入栈顶,直到其内部没有更多调用,栈顶函数将会被以单线程方式执行并出栈,直到最后一个函数帧出栈。
本文共计1284个文字,预计阅读时间需要6分钟。
JavaScript执行模型+引言+JavaScript是一个单线程(Single-threaded)的异步(Asynchronous)、非阻塞(Non-blocking)并发(Concurrent)语言,这些语言效果通过调用栈(Call Stack)和事件循环(Event Loop)实现。
JavaScript执行模型
引言
JavaScript是一个单线程(Single-threaded)异步(Asynchronous)非阻塞(Non-blocking)并发(Concurrent)语言,这些语言效果通过一个调用栈(Call Stack)、一个事件循环(Event Loop)、一个回调队列(Callback Queue)有些时候也叫任务队列(Task Queue)与跟运行环境相关的API组成。
概念
调用栈 Call Stack
调用栈是一个LIFO后进先出数据结构的函数运行栈,它内部的数据结构为函数帧。当在JavaScript中调用一个函数时,它将被压入栈中,当这个函数内部还有另一个函数被调用时,另一个函数将会被压入栈顶,直到其内部没有更多调用,栈顶函数将会被以单线程方式执行并出栈,直到最后一个函数帧出栈。

