日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Task提高異步執行效率技巧_C#教程

作者:一事冇誠 ? 更新時間: 2022-06-11 編程語言

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 GetUserNameAsync()
{
    await Task.Delay(500);
    return "小明";
}

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

private async Task 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 GetUserNameAsync()
{
    await Task.Delay(500);
    return "小明";
}

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

private async Task 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;

原文鏈接:https://www.cnblogs.com/ysmc/p/15409898.html

欄目分類
最近更新