说说C#的async和await(转)
一个简单的例子:
1 public class MyClass 2 3 { 4 5 public MyClass() 6 7 { 8 9 DisplayValue(); //这里不会阻塞 10 11 System.Diagnostics.Debug.WriteLine("MyClass() End."); 12 13 } 14 15 public Task<double> GetValueAsync(double num1, double num2) 16 17 { 18 19 return Task.Run(() => 20 21 { 22 23 for (int i = 0; i < 1000000; i++) 24 25 { 26 27 num1 = num1 / num2; 28 29 } 30 31 return num1; 32 33 }); 34 35 } 36 37 public async void DisplayValue() 38 39 { 40 41 double result = await GetValueAsync(1234.5, 1.01);//此处会开新线程处理GetValueAsync任务,然后方法马上返回 42 43 //这之后的所有代码都会被封装成委托,在GetValueAsync任务完成时调用 44 45 System.Diagnostics.Debug.WriteLine("Value is : " + result); 46 47 } 48 49 }
可以看到,async和await关键字只是把上面的代码变得更简单易懂而已。
程序的输出如下:
MyClass() End.
Value is : 2.47032822920623E-322
以下是我写的一个静态类,可以方便将一个普通Function执行异步调用:
1 public static class TaskAsyncHelper 2 { 3 /// <summary> 4 /// 将一个方法function异步运行,在执行完毕时执行回调callback 5 /// </summary> 6 /// <param>异步方法,该方法没有参数,返回类型必须是void</param> 7 /// <param>异步方法执行完毕时执行的回调方法,该方法没有参数,返回类型必须是void</param> 8 public static async void RunAsync(Action function, Action callback) 9 { 10 Func<System.Threading.Tasks.Task> taskFunc = () => 11 { 12 return System.Threading.Tasks.Task.Run(() => 13 { 14 function(); 15 }); 16 }; 17 await taskFunc(); 18 if (callback != null) 19 callback(); 20 } 21 22 /// <summary> 23 /// 将一个方法function异步运行,在执行完毕时执行回调callback 24 /// </summary> 25 /// <typeparam>异步方法的返回类型</typeparam> 26 /// <param>异步方法,该方法没有参数,返回类型必须是TResult</param> 27 /// <param>异步方法执行完毕时执行的回调方法,该方法参数为TResult,返回类型必须是void</param> 28 public static async void RunAsync<TResult>(Func<TResult> function, Action<TResult> callback) 29 { 30 Func<System.Threading.Tasks.Task<TResult>> taskFunc = ()=> 31 { 32 return System.Threading.Tasks.Task.Run(()=> 33 { 34 return function(); 35 }); 36 }; 37 TResult rlt = await taskFunc(); 38 if(callback != null) 39 callback(rlt); 40 } 41 }
原文链接:
C# 5.0中引入了async 和 await。这两个关键字可以让你更方便的写出异步代码。
看个例子:
温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/67445.html