C#异步:实现一个最简单的异步
2016-11-24 08:40 追忆似水流年 阅读(1517) 评论(0) 编辑 收藏 举报
异步就是方法异步执行, 这个好理解。
异步有啥用?
以前只是听说过, 也不想计较。 不过还是碰到了需要这个东西的时候。
比如:
定时执行, 如果不用异步方法,也不用定时器,只用Thread.Sleep来间隔。
执行方法本身需要时间,这样定时的意义就变了——两次的执行时间肯定相隔不止1分钟了。
下面是实现异步最简单的一个demo:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading; using System.Diagnostics; namespace ConsoleApplication20 { class Program { public delegate void TestDelegate(string name); static void Main(string[] args) { TestDelegate d = Test; Console.WriteLine("Beginning : {0:yyyy-MM-dd HH:mm:ss.fff}", DateTime.Now); d.BeginInvoke("小明1", null, null); d.BeginInvoke("小明2", null, null); d.BeginInvoke("小明3", null, null); d.BeginInvoke("小明4", null, null); d.BeginInvoke("小明5", null, null); Console.WriteLine("End : {0:yyyy-MM-dd HH:mm:ss.fff}", DateTime.Now); Console.Read(); } static void Test(string name) { Console.WriteLine("TestMethod: {0:yyyy-MM-dd HH:mm:ss.fff} {1}", DateTime.Now, name); } } }
由结果可见: BeginInvoke调用时确实是异步的。
附:定时器代码
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Timers; using System.Threading; namespace ConsoleApplication21 { class Program { static void Main(string[] args) { System.Timers.Timer timer = new System.Timers.Timer(); timer.Enabled = true; timer.Interval = 1000; timer.Start(); timer.Elapsed += new ElapsedEventHandler(PrintPoint); Console.WriteLine("End"); Console.Read(); } static void PrintPoint(object sender, ElapsedEventArgs e) { DateTime dtCurr = DateTime.Now; Console.WriteLine("{0:yyyy-MM-dd HH:mm:ss.fff}", dtCurr); Thread.Sleep(2000); Console.WriteLine("{0:yyyy-MM-dd HH:mm:ss.fff}_{1:yyyy-MM-dd HH:mm:ss.fff}", dtCurr, DateTime.Now); } } }
由结果可见:定时器的事件也是异步的, 每个事件即使执行时间较长, 也不会造成下一个定时事件的延时执行。
原文出处:http://blog.csdn.net/yenange/article/details/50541421