js的线程问题
Posted iiiLISA
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js的线程问题相关的知识,希望对你有一定的参考价值。
主动学习。
同步异步代码
同步代码:按书写顺序执行
异步代码:(异步操作)
计时器(setTimeout,setInterval),
网络请求(ajax),
读取文件,
then,
鼠标键盘触发事件
区别:异步不会阻塞程序的执行;同步会阻塞程序的执行。
同步代码执行完成之后再执行异步代码。
console.log(1);
setTimeout(function()console.log(2),0);
setTimeout(function()console.log(3),0);
console.log(4);
输出1423
for(let i=0;i<2000;i++)
console.log(1);
setTimeout(function()console.log(2),0);
setTimeout(function()console.log(3),0);
console.log(4);
//输出2000个1,再输出423
//如果2插入2000个1中输出说明代码是同时执行的,不是按照顺序执行的了。
单线程
JS是单线程的,一个任务完成之后才能执行另一个任务。
setImmediate(()=>//只能在js文件中运行
console.log(1);
)
process.nextTick(()=>
console.log(2);
);
console.log(3);
setTimeout(()=>
console.log(4)
,0);
console.log(5);
//输出35241
事件循环(event loop)
同步代码放入运行栈中
异步代码放入任务队列
注:同步代码放入运行栈中,异步代码在时间到之后放入任务队列中。
执行栈中的任务清空后,再读取任务队列。
事件循环一直检测任务队列中是否有任务,有则执行。
(因为异步代码在时间到之后放入任务队列中,而不是立即执行,因此计时器有时候不是很准。)
该过程循环执行。
宏任务与微任务
js将异步任务又分为了宏任务和微任务。
宏任务:计时器,ajax,读取文件,script(整体代码)
微任务:promise.then,.catch, .finally
执行顺序:
1.同步程序
2.process.nextTick
3.微任务
4.宏任务
5.setImmediate
setImmediate(() =>
console.log(1)
)
console. log(2);
setTimeout(() => console.log(3),0);
setTimeout(() => console . log(4),100);
console. log(5);
new Promise((resolve) =>
console.log(6)
resolve( )//调用resolve的时候执行then,否则不执行then
).then(() =>
console.log(7)
)
process. nextTick(() =>
console . log(8)
)
输出25687314
js引擎又叫js内核,负责处理js脚本程序。
为了利用多核CPU的能力,html5提出Web Worker标准,允许JS脚本创建多个线程,但是子线程完全受主线程控制,且不得操作DOM。这个新标准并没有改变js单线程的本质。
以上是关于js的线程问题的主要内容,如果未能解决你的问题,请参考以下文章