阅读 48

JavaScript是单线程吗

在一次面试中,被问到这个问题 =》 JavaScript是单线程吗

JS在浏览器中运行,是单线程的. 每个window只有一个JS线程. 既然是单线程的,那么在某个特定的时刻,也就应该只有特定的代码才能够被执行,并阻塞其他的代码. 但是我们明明又发现,比如JQuery的AJAX异步调用,

而我们知道,浏览器是事件驱动的(Event Driven), 浏览器中很多行为都是异步(Asynchronized)的,浏览器会创建事件并放入执行队列中. 也就是说,浏览器内部有一个事件大循环,或者说消息大循环,叫做Event Loop(事件循环), 会轮询事件队列。

所以可以理解如下:

JS引擎是单线程来处理它的任务队列的。比如JS单线程目前正在处理一个任务. 这个时候,发生了mouse click, a timer firing, or an XMLHttpRequest completing (需要JavaScript去处理鼠标点击事件,定时器触发事件, XMLHttpRequest回调触发等)。会把这些事件放入到Event Loop(事件循环)中,等JS当前任务执行完毕,才会去依次执行它们.

我们来看一个经典的例子

function foo() {
    console.log( ‘first‘ );
    setTimeout( ( function(){ console.log( ‘second‘ ); } ), 5);
 
}
 
for (var i = 0; i < 1000000; i++) {
    foo();
}

这段代码的执行结果会 首先全部输出first, 然后再全部输出second

JS单线程在这里先是执行console.log(‘first‘), 然后5毫秒后,把setTimeout这个任务加入到等待队列Event Loop中(注意: 不是5毫秒后马上执行它,而是5毫秒后把它加入到等待队列,因为现在JS单线程很忙)

JS单线程在忙着完成当前的事情,也就是1000000次循环输出first.

只能等1000000个first输出完后才会输出second)

 

原文:https://www.cnblogs.com/wphl-27/p/15335214.html

文章分类
代码人生
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐