C# 5.0引入了兩個關鍵字async和await,這兩個關鍵字在很大程度上幫助我們簡化了非同步程式設計的實作程式碼,而且TPL中的task與async和await有很大的關係
private async void button1_Click(object sender, EventArgs e) { var length = AccessWebAsync(); // 这里可以做一些不依赖回复的操作 OtherWork(); this.textBox1.Text += String.Format("\n 回复的字节长度为: {0}.\r\n", await length); this.textBox2.Text = Thread.CurrentThread.ManagedThreadId.ToString(); } private async Task<long> AccessWebAsync() { MemoryStream content = new MemoryStream(); // 对MSDN发起一个Web请求 HttpWebRequest webRequest = WebRequest.Create("http://msdn.microsoft.com/zh-cn/") as HttpWebRequest; if (webRequest != null) { // 返回回复结果 using (WebResponse response = await webRequest.GetResponseAsync()) { using (Stream responseStream = response.GetResponseStream()) { await responseStream.CopyToAsync(content); } } } this.textBox3.Text = Thread.CurrentThread.ManagedThreadId.ToString(); return content.Length; } private void OtherWork() { this.textBox1.Text += "\r\n等待服务器回复中.................\n"; }
async是同步執行程序,而await起到的則是劃分片段以及掛起調用方的作用,並不會創建新的線程,根據大神的分析:
在await關鍵字出現的前面部分程式碼和後面部分程式碼都是同步執行的(即在呼叫線程上執行的,也就是GUI線程,所以不存在跨線程存取控制項的問題),await關鍵處的程式碼片段是在線程池線程上執行。
在上面的程式碼中,呼叫了FCL封裝的GetResponseAsync等方法從而不阻塞當前UI線程,await的確不會創建新的線程,但是就在這裡而言,await表達式中的確創建了新的線程——GetResponseAsync所做的.以至於造成了表面同步的假象。我之前寫過一篇文章
C#async與await異步編程學習筆記
await關鍵字與Task有莫大的關聯,從其特定的返回值就可以看出來,更深層次的await與task的continuewith函數應該是等效的.因此,用async & await關鍵字實現異步要么調用FCL封裝好的異步方法,要么我們就自己調用task來創建新的線程分擔UI線程的任務以防止UI線程阻塞.
以上是C# 5.0引入了兩個關鍵字 --async和await的詳細內容。更多資訊請關注PHP中文網其他相關文章!