JavaScript setTimeout 的原理

JavaScript 引擎是基于事件驱动单线程执行的,JavaScript 引擎一直等待着任务队列中的任务,接收到任务就加以处理,任务过多时会按序等待处理。

setTimeout 调用的时候,JavaScript引擎会启动定时器 timer,在第二个参数 n 毫秒 以后执行第一个参数回调或代码段,当定时器的时间到了,就把该事件放到主事件队列等待处理。

也就是说需要看任务放到队列中的顺序。

var waiting = (number)=> {
    var now = new Date();
    var untilEnd = now.getTime() + number;
    while (true) {
        now = new Date();
        if (now.getTime() > untilEnd)
            return;
    }
}
(()=> {
    setTimeout(()=> console.log("空闲时,调用了延时回调"), 100);
    console.log("理论上在 100ms 后调用延时回调");

    waiting(100);
    console.log("等了 100ms");

    setTimeout(()=> console.log("我虽然 10ms 延迟短,但是我排在队列的最后。"), 10);
})();

waiting(500);
console.log("又等了 500ms,之后");

结果:

理论上在 100ms 后调用延时回调
等了 100ms
又等了 500ms,之后
空闲时,调用了延时回调
我虽然 10ms 延迟短,但是我排在队列的最后。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值