js--->单线程

js--->单线程

 严格意义上来说,
javascript没有多线程的概念,所有的程序都是单线程依次执行的。

  
1、什么是单线程?

  通俗点说,就是代码在执行过程中,另一段代码想要执行就必须等当前代码执行完成后才可以进行。我们拿一段代码来解释一下吧

1 for(var i=1;i<=3;i++){2 setTimeout(function(){3 console.log(i); //输出:4,4,44 },0)5 }

  我们来看一下上面的这段代码,既然延时器时间设置为
0,那么应该执行一遍循环就应该立即打印出一个i,但是最终的打印结果为:4,4,4。之所以会出现上面的结果,正是因为js代码是单线程应用。

  在执行过程中,先遇到
for循环,for循环先进入线程。当i=1时,循环走到setTimeOut后,此时的for循环还没有执行完成,setTimeOut就会被放入一个地方(线程池)等待执行。此时for循环继续执行,当i=2时,for循环仍没有执行完,这时的setTimeOut仍会被放在线程池中等待执行……依次类推,直到for循环转完3遍后,for循环执行完了,此时线程空闲了,在线程池中等待执行的setTimeOut依次执行打印i,而for循环执行完成后,i变成了4,所以打印出了三个4。

  
2、如果想要改变上面的状况可以运用以下代码

//将var变为letfor(let i=1; i<=3; i++){

setTimeOut(function(){

console.log(i); //输出的结果为1,2,3

},0);

}//用自执行函数进行包裹for(var i=1; i<=3; i++){

!function(i){

setTimeOut(function(){

console.log(i); //输出的结果为1,2,3

},0);

}(i)

想要学习前端开发的同学,可以加群:
543627393 学习哦!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值