〇、导言
JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事。那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊。
JavaScript的单线程,与它的用途有关。作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM。这决定了它只能是单线程,否则会带来很复杂的同步问题。比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准?
所以,为了避免复杂性,从一诞生,JavaScript就是单线程,这已经成了这门语言的核心特征,将来也不会改变。
为了利用多核CPU的计算能力,HTML5提出Web Worker标准,允许JavaScript脚本创建多个线程,但是子线程完全受主线程控制,且不得操作DOM。所以,这个新标准并没有改变JavaScript单线程的本质。
引用自阮一峰:JavaScript 运行机制详解:再谈Event Loop
一、最重要的原因:简单性
二、有人说setTimeout或者Promise可以模拟多线程,然后我笑了╮(╯_╰)╭
三、例子说明
1、只有setTimeout
function example1 () {
let start = Date.now()
for (let i = 0; i < 10; i++) {
setTimeout(() => {
for (let _ = 0; _ < 1e9; _++);
console.log(`between`, Date.now() - start)
})
}
}
2、只有Promise
function example2 () {
let start = Date.now()
for (let i = 0; i < 10; i++) {
new Promise((resolve) => {
for (let _ = 0; _ < 1e9; _++);
console.log(`between`, Date.now() - start)
})
}
}
3、Promise和setTimeout混用
function example3 () {
let start = Date.now()
for (let i = 0; i < 10; i++) {
new Promise((resolve) => {
setTimeout(() => {
for (let _ = 0; _ < 1e9; _++);
console.log(`between`, Date.now() - start)
})
})
}
}
3个结果都是如此:
四、结论
js本身不存在多线程可行性,webworker做的多线程是浏览器的多线程,也就是说:自浏览器诞生至今,赋予js的就只有单线程。那万一有人想搞js多线程还有机会吗?答案是:浏览器说——除非我死了