alert("start");
var t = true;
window.setTimeout(function(){
t = false;
}, 1000);
while(t){
}
alert("end");
死循环原因解释
事件触发线程,当一个事件被触发时该线程会把事件添加到待处理队列的队尾,等待JS引擎的处理。这些事件可来自JavaScript引擎当前执行的代码块如setTimeOut、也可来自浏览器内核的其他线程如鼠标点击、AJAX异步请求等,但由于JS的单线程关系所有这些事件都得排队等待JS引擎处理。(当线程中没有执行任何同步代码的前提下才会执行异步代码)
setTimeout(function() {
console.log(123);
var s = new Date();
var n = s.getTime();
console.log(n);
}, 0);
for (var i = 0; i < 50; i++) {
console.log(new Date().getTime());
};
扩展资料
http://www.infoq.com/cn/articles/js_multithread
http://www.suchso.com/projecteactual/Javascript-setTimeout-timer.html
http://www.ibm.com/developerworks/cn/web/1105_chengfu_jsworker/
https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setTimeout