Task 异步小技巧

async Task 语法糖出来后,异步编程变得非常简单,适合需要耗费较长时间的任务。

有些小伙伴使用后可能会非常疑惑,使用异步和同步,在耗时上几乎没有差别。

下面我们看一个例子,场景是需要调用多个第三方的WebApi,分别是获取名称、年龄、性别,由于网络环境等原因,api响应时间可能会接近1秒

public async Task Test()
{
    var sw = new Stopwatch();
    sw.Start();

    var userName = await GetUserNameAsync();
    var userAge = await GetUserAgeAsync();
    var userSex = await GetUserSexAsync();

    sw.Stop();
    var ts = sw.Elapsed;
    Console.WriteLine($"总共耗时:{ts.TotalMilliseconds}ms");
}

private async Task<string> GetUserNameAsync()
{
    await Task.Delay(500);
    return "小明";
}

private async Task<string> GetUserAgeAsync()
{
    await Task.Delay(800);
    return "11";
}

private async Task<string> GetUserSexAsync()
{
    await Task.Delay(900);
    return "11";
}

运行后发现,这个时间2秒多,这用户体验肯定是无法忍受的
在这里插入图片描述
导致这样结果的原因是每次进行异步调用的时候,都在异步函数前加上了 await ,这会导致该线程阻塞,等待直到结果返回,每个异步函数都await,时间自然就叠加了,为了解决这个问题,使用一个小技巧,可以将代码改成下面这样

public async Task Test()
{
    var sw = new Stopwatch();
    sw.Start();

    var userNameTask =  GetUserNameAsync();
    var userAgeTask =  GetUserAgeAsync();
    var userSexTask =  GetUserSexAsync();

    var userName = await userNameTask;
    var userAge = await userAgeTask;
    var userSex = await userSexTask;

    sw.Stop();
    var ts = sw.Elapsed;
    Console.WriteLine($"总共耗时:{ts.TotalMilliseconds}ms");
}

private async Task<string> GetUserNameAsync()
{
    await Task.Delay(500);
    return "小明";
}

private async Task<string> GetUserAgeAsync()
{
    await Task.Delay(800);
    return "11";
}

private async Task<string> GetUserSexAsync()
{
    await Task.Delay(900);
    return "11";
}

这次运行的总耗时,就是3个异步中,耗时最长那个 GetUserSexAsync
在这里插入图片描述
为什么会这样呢,这个小技巧的关键是这里,当执行到异步函数的时候,不加 await,不进行等待,这样就不会造成阻塞,让这些任务乖乖在别的线程的执行,当需要用到他们的时候,再去等待返回值,所以时间上不会进行叠加,哪个最长,总耗时就是哪个

var userNameTask =  GetUserNameAsync();
var userAgeTask =  GetUserAgeAsync();
var userSexTask =  GetUserSexAsync();

var userName = await userNameTask;
var userAge = await userAgeTask;
var userSex = await userSexTask;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值