不会溢出。
原因,这不是一个“死循环”。
//这才是死循环,函数的调用堆栈会不断变大。直到溢出。
function func(){
//函数体
func();
}
//但是,加上setTimeout之后,就不是死循环
//因为1秒之后,setTimeout会开启一个新的函数调用堆栈。跟上一次的不是同一个。因此不会产生调用堆栈不断变大直到溢出的情况。
function func(){
//函数体
setTimeout(function(){
func();
},1000);
}
流程是这样的。
步骤1:创建一个调用堆栈,执行func函数,func函数中注册了一个定时器。func执行上下文销毁。
步骤2:1秒钟之后(不能保证一定是1秒钟,理想情况下是1秒钟),定时器触发
步骤3:创建一个新的调用堆栈,执行定时器中注册的回调函数-- func。重复步骤1.
你这样写就是个递归,你不会在里面给个判断啊,满足就不进行
setTimeout函数不是每t时间执行一次,而是t时间后执行一次,仅一次而已
所以你可以这样
if(true) setTimeot(XXX);
else alert('');