javaScript之深入理解同步与异步

同步和异步

  • 同步,可以阻塞也可以非阻塞;异步可以阻塞也可以非阻塞;
  • 但是同步和异步都是是一种消息通知机制。js中是同步阻塞,异步非阻塞。
  • 同步阻塞: A调用B,B处理获得结果,才返回给A。A在这个过程中,一直等待B的处理结果,没有拿到结果之前,需要A(调用者)一直等待和确认调用结果是否返回,拿到结果,然后继续往下执行。
  • 异步非阻塞: A调用B,无需等待B的结果,B通过状态,通知等来通知A或回调函数来处理。

主线程和异步线程

console.log(111);
function test(){
    console.log("test");
}
test();
function asyncFn1(){
    // 异步函数
    setTimeout(()=>{
        console.log("asyncFn1");
    },2000)
}
asyncFn1();
function asyncFn2(){
    // 异步函数
    setTimeout(()=>{
        console.log("asyncFn2");
    },2000)
}
asyncFn2();
console.log(222);

结果:

111
test
222
asyncFn1
asyncFn2

异步问题

function asyncFn(){
    setTimeout(()=>{
        console.log("asyncFn");
    })
}
asyncFn();  //后执行
console.log("somevalue");  //先执行

结果:

somevalue
asyncFn
  • 异步执行完后再执行其他逻辑
function asyncFn(cb){
    setTimeout(()=>{
        console.log("asyncFn");
        // 容错处理 
        cb && cb();
    })
};
asyncFn(function(){
    // 异步执行完成后的代码
    console.log("somevalue");
});

结果:

asyncFn
somevalue
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值