转自:http://blog.csdn.net/aitangyong/article/details/46800615浏览器
今天看了下Promise的使用,提到了setTimeout的异步实现,看到上文,很是有帮助理解,mark一下。异步
重点以下:函数
JavaScript是单线程执行的,没法同时执行多段代码。当某一段代码正在执行的时候,全部后续的任务都必须等待,造成一个队列。一旦当前任务执行完毕,再从队列中取出下一个任务,这也常被称为 “阻塞式执行”。因此一次鼠标点击,或是计时器到达时间点,或是Ajax请求完成触发了回调函数,这些事件处理程序或回调函数都不会当即运行,而是当即排队,一旦线程有空闲就执行。假如当前 JavaScript线程正在执行一段很耗时的代码,此时发生了一次鼠标点击,那么事件处理程序就被阻塞,用户也没法当即看到反馈,事件处理程序会被放入任务队列,直到前面的代码结束之后才会开始执行。若是代码中设定了一个 setTimeout,那么浏览器便会在合适的时间,将代码插入任务队列,若是这个时间设为 0,就表明当即插入队列,但不是当即执行,仍然要等待前面代码执行完毕。因此 setTimeout 并不能保证执行的时间,是否及时执行取决于 JavaScript 线程是拥挤仍是空闲。.net