为什么将Javascript设计为单线程?

Javascript是单线程的,这点好多人知道,一些关于单线程的任务执行以及线程池的概念也不新鲜.

那大家有没有想过,为什么将Javascript设计为单线程?Why?

阅读 6.8k
5 个回答

JavaScript 语言本身没有被设计成单线程,最多只能说没有内置多线程支持。SSJS 我不清楚,但至少 CSJS(浏览器)已经开始支持多线程了(Web Workers)。之前之所以没有,是因为:

  1. 多线程程序逻辑会复杂很多。如果简单的够用,何必弄很复杂呢
  2. 需求不多。早期的网页上的 JavaScript 都是很轻量的

现在以上两个理由都不怎么能成立了,所以浏览器渐渐有 Web Workers 支持了嘛。

因为线程很昂贵。

一个程序员,到了一家赶进度的公司,分配了一个不太想做的事情,怎么办?速决。怎么简单怎么来。
这个程序员就是Brendan Eich,公司netscape ,人家本来要做schema,现在做了js。
根据一些材料,我乱猜的:)

客户端js我不清除
但我知道node.js

node.js确实是单线程,但这个单线程有后台线程池的支持。
每一个异步操作提交后,都交由后台线程执行,执行结束,异步操作的回调函数被调用。

客户端js应该也差不远。

因为线程要留着给资源的加载。

资源的加载是io,io就要等中断,等中断的时间可以抵的过上下文切换的开销。

而浏览器内是沙箱环境,不允许任何本地的读写操作,也就不会有任何io,所以就设计成单线程的免得抢调度。

后来有了ajax,只能将就了。

后来js到了服务端,需要很多io操作。但是node是基于v8的,v8官方是用来给浏览器设计的,只是node拿来做服务端,没办法。于是就有了很多非三方的线程库。但是这单线程异步模型(或者叫纤程)是约定俗成了。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题