1.代码会经过编译阶段,编译阶段会创建上下文环境变量,什么情况会创建上下文?
- 全局代码,会被创建全局执行上下文,而且在整个页面的生存周期内,全局执行上下文只有一份。
- 当调用一个函数的时候,函数体内的代码会被编译,并创建函数执行上下文,一般情况下,函数执行结束之后,创建的函数执行上下文会被销毁。
- 当使用 eval 函数的时候,eval 的代码也会被编译,并创建执行上下文。
var a = 2
function add(){
var b = 10
return a+b
}
add()
1.什么是 JavaScript 的调用栈?
JavaScript 引擎正是利用栈的这种结构来管理执行上下文的。在执行上下文创建好后,JavaScript 引擎会将执行上下文压入栈中,通常把这种用来管理执行上下文的栈称为执行上下文栈,又称调用栈。
var a = 2
function add(b,c){
return b+c
}
function addAll(b,c){
var d = 10
result = add(b,c)
return a+result+d
}
addAll(3,6)
- 全局上下文创建好后进栈
- 调用addAll时,创建函数上下文
- 第三步,当执行到 add 函数
- 执行完add函数,出栈
2. 栈溢出(Stack Overflow)
调用栈是有大小的,当入栈的执行上下文超过一定数目,JavaScript 引擎就会报错,我们把这种错误叫做栈溢出。
function division(a,b){
return division(a,b)
}
console.log(division(1,2))