日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

考虑用Task.WhenAll

發(fā)布時(shí)間:2023/12/4 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 考虑用Task.WhenAll 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

異步能在一定場(chǎng)景中帶性能的飛躍,同步調(diào)用性能,也以帶來(lái)時(shí)間的節(jié)省。

先看一下被調(diào)用的api:

using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks;namespace WebAPI.Controllers {[ApiController][Route("[controller]")]public class HomeController : ControllerBase{private readonly ILogger<HomeController> _logger;public HomeController(ILogger<HomeController> logger){_logger = logger;}[HttpGet("/api001")]public async Task<IActionResult> GetAPI001(){_logger.LogInformation("GetAPI001");await Task.Delay(1000);return new JsonResult(new { result = true, data = "api001 返回成功" });}[HttpGet("/api002")]public async Task<IActionResult> GetAPI002(){_logger.LogInformation("GetAPI002");await Task.Delay(1000);if (DateTime.Now.Second % 2 == 0){throw new Exception("api002異常");}return new JsonResult(new { result = true, data = "api002 返回成功" });}[HttpGet("/api003")]public async Task<IActionResult> GetAPI003(){_logger.LogInformation("GetAPI003");await Task.Delay(1000);return new JsonResult(new { result = true, data = "api003 返回成功" });}} }

調(diào)用時(shí)反序列化的實(shí)體類

class ResponseResult<T>{public bool Result { get; set; }public string Message { get; set; }public T Data { get; set; }}

三個(gè)api的調(diào)用方法

private static async Task<string> GetAPI001(HttpClient httpClient) {var content = await httpClient.GetStringAsync("http://localhost:5000/api001");var result = JsonSerializer.Deserialize<ResponseResult<string>>(content, new JsonSerializerOptions { PropertyNameCaseInsensitive = true });if (result.Result){return result.Data;}else{return result.Message;} } private static async Task<string> GetAPI002(HttpClient httpClient) {var content = await httpClient.GetStringAsync("http://localhost:5000/api002");var result = JsonSerializer.Deserialize<ResponseResult<string>>(content, new JsonSerializerOptions { PropertyNameCaseInsensitive = true });if (result.Result){return result.Data;}else{return result.Message;} } private static async Task<string> GetAPI003(HttpClient httpClient) {var content = await httpClient.GetStringAsync("http://localhost:5000/api003");var result = JsonSerializer.Deserialize<ResponseResult<string>>(content, new JsonSerializerOptions { PropertyNameCaseInsensitive = true });if (result.Result){return result.Data;}else{return result.Message;} }

同步的調(diào)用方式

static async Task SyncCall() {using var httpClient = new HttpClient();try{var result1 = await GetAPI001(httpClient);WriteLine(result1);}catch (Exception exc){WriteLine(exc.Message);}try{var result2 = await GetAPI002(httpClient);Console.WriteLine(result2);}catch (Exception exc){WriteLine(exc.Message);}try{var result3 = await GetAPI003(httpClient);Console.WriteLine(result3);}catch (Exception exc){WriteLine(exc.Message);} }

調(diào)用方式

static async Task Main(string[] args) {while (true){WriteLine("回車開(kāi)始執(zhí)行");ReadLine();var stopwatch = Stopwatch.StartNew();await SyncCall();WriteLine($"用時(shí){stopwatch.ElapsedMilliseconds}ms");} }

同步的調(diào)用,運(yùn)行三次調(diào)用是三次的時(shí)間,3202ms,如果有異常不干擾其他api調(diào)用。

static async Task AsyncCall() {using var httpClient = new HttpClient();var allTasks = Task.WhenAll(GetAPI001(httpClient), GetAPI002(httpClient), GetAPI003(httpClient));try{var results = await allTasks;foreach (var result in results){Console.WriteLine(result);}}catch (Exception exc){Console.WriteLine($"捕捉到的異常:{exc.Message}");}if (allTasks.Exception != null){Console.WriteLine($"AllTasks異常:{ allTasks.Exception.Message}");} }

同步調(diào)用成功時(shí)間是1156ms,時(shí)間縮短了,但三個(gè)api調(diào)用,如果有異常,則全軍覆沒(méi)。

先擇適合的方式,打造更優(yōu)的應(yīng)用。

總結(jié)

以上是生活随笔為你收集整理的考虑用Task.WhenAll的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。