迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > TypeScript >

TypeScript 中的睡眠

作者:迹忆客 最近更新:2023/03/19 浏览次数:

在实现业务逻辑时,经常需要给函数添加延迟或者休眠一段时间等待某个 API 调用。

本篇文章将讨论在 TypeScript 中休眠线程的不同方式和概念。

在 TypeScript 中使用阻塞来休眠线程

阻塞可用于以同步方式等待一段时间。下面的代码示例演示了如何阻止线程,以便在几秒钟后执行。

function delayBlocking(milliseconds: number){
    const timeInitial : Date = new Date();
    var timeNow : Date = new Date();
    for ( ; timeNow - timeInitial < milliseconds; ){
        timeNow = new Date();
    }
    console.log('Sleep done!');
}

console.log('Starting, will sleep for 5 secs now');
delayBlocking(5000);
console.log('Normal code execution continues now');

输出:

Starting, will sleep for 5 secs now
Sleep done!
Normal code execution continues now

上面的代码段肯定会停止执行一段时间,但有时这并不是想要的效果,因为延迟很大,整个代码都会被阻塞。

在 TypeScript 中使用 Promise 休眠

setTimeout 函数用于在一些延迟后解决 Promise。此方法可以与 thenasync...await 链接。以下代码段显示了 then 的行为。

function delay(milliseconds : number) {
    return new Promise(resolve => setTimeout( resolve, milliseconds));
}

console.log('Starting, will sleep for 5 secs now');
delay(5000).then(() => console.log('Normal code execution continues now') );

使用 async..await 它可以根据以下代码段实现-

function delay(milliseconds : number) {
    return new Promise(resolve => setTimeout( resolve, milliseconds));
}
( async() => {
    console.log('Starting, will sleep for 5 secs now');
    await delay(5000);
    console.log('Normal code execution continues now');
})();

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 TypeScript 中返回一个 Promise

发布时间:2023/03/19 浏览次数:182 分类:TypeScript

本教程讨论如何在 TypeScript 中返回正确的 Promise。这将提供 TypeScript 中 Returns Promise 的完整编码示例,并完整演示每个步骤。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便