一個簡單的例子看明白 async await Task

来源:https://www.cnblogs.com/s0611163/archive/2020/04/16/12711106.html
-Advertisement-
Play Games

測試代碼: 1 using System; 2 using System.Collections.Generic; 3 using System.ComponentModel; 4 using System.Data; 5 using System.Drawing; 6 using System.L ...


測試代碼:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.ComponentModel;
  4 using System.Data;
  5 using System.Drawing;
  6 using System.Linq;
  7 using System.Text;
  8 using System.Threading;
  9 using System.Threading.Tasks;
 10 using System.Windows.Forms;
 11 using Utils;
 12 
 13 namespace test
 14 {
 15     public partial class Form1 : Form
 16     {
 17         public Form1()
 18         {
 19             InitializeComponent();
 20         }
 21 
 22         private void Form1_Load(object sender, EventArgs e)
 23         {
 24 
 25         }
 26 
 27         /// <summary>
 28         /// 執行任務
 29         /// </summary>
 30         public string DoWork(string str)
 31         {
 32             Thread.Sleep(3000); //模擬延遲 比如網路請求 用了3000毫秒
 33             return "輸出:" + str;
 34         }
 35 
 36         /// <summary>
 37         /// 執行任務
 38         /// </summary>
 39         public Task<string> DoWorkByTask(string str)
 40         {
 41             return Task.Run(() =>
 42             {
 43                 Thread.Sleep(3000); //模擬延遲 比如網路請求 用了3000毫秒
 44                 return "輸出:" + str;
 45             });
 46         }
 47 
 48         /// <summary>
 49         /// 測試1
 50         /// </summary>
 51         private async void button1_Click(object sender, EventArgs e)
 52         {
 53             LogTimeUtil logTime = new LogTimeUtil();
 54 
 55             var t1 = DoWorkByTask("測試值1");
 56 
 57             var t2 = DoWorkByTask("測試值2");
 58 
 59             string r1 = await t1;
 60 
 61             textBox1.AppendText(r1 + "\r\n");
 62 
 63             string r2 = await t2;
 64 
 65             textBox1.AppendText(r2 + "\r\n");
 66 
 67             logTime.LogTime("耗時", textBox1);
 68         }
 69 
 70         /// <summary>
 71         /// 測試2 
 72         /// 
 73         /// 等效於 測試1
 74         /// </summary>
 75         private void button2_Click(object sender, EventArgs e)
 76         {
 77             Task.Run(() => //如果不加Task.Run,界面會卡
 78             {
 79                 LogTimeUtil logTime = new LogTimeUtil();
 80 
 81                 Task<string> t1 = Task.Run<string>(() => { return DoWork("測試值1"); });
 82                 Task<string> t2 = Task.Run<string>(() => { return DoWork("測試值2"); });
 83 
 84                 Task.WaitAll(t1, t2);
 85 
 86                 this.Invoke(new Action(() => //線程中修改控制項數據要使用Invoke
 87                 {
 88                     textBox1.AppendText(t1.Result + "\r\n");
 89                     textBox1.AppendText(t2.Result + "\r\n");
 90                 }));
 91 
 92                 logTime.LogTime("耗時", textBox1);
 93             });
 94         }
 95 
 96         /// <summary>
 97         /// 測試3 
 98         /// </summary>
 99         private async void button3_Click(object sender, EventArgs e)
100         {
101             LogTimeUtil logTime = new LogTimeUtil();
102 
103             var r1 = await DoWorkByTask("測試值1");
104 
105             textBox1.AppendText(r1 + "\r\n");
106 
107             var r2 = await DoWorkByTask("測試值2");
108 
109             textBox1.AppendText(r2 + "\r\n");
110 
111             logTime.LogTime("耗時", textBox1);
112         }
113 
114         /// <summary>
115         /// 測試4
116         /// 
117         /// 等效於 測試3
118         /// </summary>
119         private void button4_Click(object sender, EventArgs e)
120         {
121             Task.Run(() => //如果不加Task.Run,界面會卡
122             {
123                 LogTimeUtil logTime = new LogTimeUtil();
124 
125                 Task<string> t1 = Task.Run<string>(() => { return DoWork("測試值1"); });
126                 t1.Wait();
127                 this.Invoke(new Action(() => //線程中修改控制項數據要使用Invoke
128                 {
129                     textBox1.AppendText(t1.Result + "\r\n");
130                 }));
131 
132                 Task<string> t2 = Task.Run<string>(() => { return DoWork("測試值2"); });
133                 t2.Wait();
134                 this.Invoke(new Action(() => //線程中修改控制項數據要使用Invoke
135                 {
136                     textBox1.AppendText(t2.Result + "\r\n");
137                 }));
138 
139                 logTime.LogTime("耗時", textBox1);
140             });
141         }
142 
143     }
144 }
View Code

測試輸出:

附 LogTimeUtil.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace Utils
{
    /// <summary>
    /// 記錄耗時
    /// </summary>
    public class LogTimeUtil
    {
        private DateTime _lastTime;

        public LogTimeUtil()
        {
            _lastTime = DateTime.Now;
        }

        /// <summary>
        /// 記錄耗時
        /// </summary>
        public void LogTime(string msg)
        {
            double d = DateTime.Now.Subtract(_lastTime).TotalSeconds;
            LogUtil.Log(msg + ",耗時:" + d.ToString("0.000") + "");
        }

        /// <summary>
        /// 記錄耗時
        /// </summary>
        public void LogTime(string msg, TextBox txt)
        {
            double d = DateTime.Now.Subtract(_lastTime).TotalSeconds;
            msg = msg + ",耗時:" + d.ToString("0.000") + " 秒\r\n";
            if (txt.InvokeRequired)
            {
                txt.Invoke(new Action(() =>
                {
                    txt.AppendText(msg);
                }));
            }
            else
            {
                txt.AppendText(msg);
            }
        }
    }
}
View Code

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • .NET 下基於動態代理的 AOP 框架實現揭秘 Intro 之前基於 Roslyn 實現了一個簡單的條件解析引擎,想瞭解的可以看這篇文章 執行過程中會根據條件的不同會在運行時創建一個類,每一次創建都會生成一個新的程式集,我覺得這樣實現的話可能會導致載入的程式集越來越多,雖然目前我們的使用場景下不會 ...
  • 1、需求 前段時間有個需求,要求把網頁生成pdf,找了各種插件,才決定使用這個TuesPechkin,這個是後臺採用C#代碼進行生成 2、做法 我要做的是一個比較簡單的頁面,採用MVC綁定,數據動態載入,頁面上給個按鈕,點擊後請求後臺介面,便可以生成pdf文件了 3、實現方式 引入兩個相關DLL,T ...
  • private void timer1_Tick(object sender, EventArgs e) { label1.Left -= 2; if (label1.Right < 0) { label1.Left = this.Width; } } 在窗體的定時器上編寫上面的代碼就可以看到效果了 ...
  • 只讀的自動屬性 通過聲明只有get訪問器的自動屬性,實現該屬性只讀 public string FirstName { get; } public string LastName { get; } 自動只讀屬性在能在構造函數中賦值,任何其他地方的賦值都會報編譯錯誤。 自動屬性初始化器 在聲明自動屬性 ...
  •  <import name="address" src="../Common/ui/h-ui/advance/c_address"></import> <template> <div class="container"> <address header-text="聯繫作者" header-sty ...
  • 護照資料也下方的兩行成為MRZ碼(或護照機讀碼),每行44個字元(0 9,A Z,<),如下例: 1 2 3 4 5 6 7 8 9 101 2 3 4 5 6 7 8 9 201 2 3 4 5 6 7 8 9 301 2 3 4 5 6 7 8 9 401 2 3 4 P O C H N Z H ...
  • 前幾天要做一個數據導出Excel 我就打算寫一個通用的。 這樣一來用的時候也方便,數據主要是通過Orm取的List。這樣寫一個通用的剛好。 public static void ListToExcel(List<dynamic> ts, string[] RowName, string[] List ...
  • 最近很對朋友、同事問起,vs怎麼自動把css、js合併壓縮,所以這裡簡單說說介紹 插件功能、特征說明: 1、將CSS,JavaScript或HTML文件捆綁到單個輸出文件中 2、保存源文件會自動觸發重新捆綁 3、縮小單個或捆綁的CSS,JavaScript和HTML文件 4、支持globbing模式 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...