原文链接:https://note.noxussj.top/?source=cloudtencent
我们写的 JS 代码大多数都是同步模式,也就是从上往下依次执行。后一个任务必须要等前一个任务结束才能开始执行,程序的执行顺序和我们代码的编写顺序是完全一致的。程序执行中每遇到一个任务都会先入栈,当前入栈的任务执行完毕后就会出栈。本来栈的概念是留到数据结构算法在讲的,但是这里用到了可以提前介绍一下。
栈是基础数据结构,栈是一种遵循后进先出原则的有序集合,添加新元素的一端称为栈顶,另一端称为栈底,操作栈的元素时,只能从栈顶操作(添加、移除、取值)。
下面通过代码的例子和调试工具去更好的理解栈和 JS 调用栈。
console.log('global begin')
function bar() {
console.log('bar task')
}
function foo() {
console.log('foo task')
bar()
}
foo()
console.log('global end')
执行顺序如下
在浏览器调试工具右侧可以看到调用栈:
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。