C#异步编程的实现方式(4)——Task任务
.Net Framework 4.0新增了一個(gè)System.Threading.Tasks命名空間,它包含的類提供了任務(wù)的相關(guān)操作。使用任務(wù)不僅可以獲得一個(gè)抽象層,還能對底層線程進(jìn)行很多統(tǒng)一的控制操作。這里先介紹一下Task的簡單使用。
最基本的是知道怎么啟動(dòng)一個(gè)Task。
?
1、Task類構(gòu)造函數(shù)
使用Task類的構(gòu)造函數(shù)。實(shí)例化Task對象時(shí),任務(wù)不會(huì)立即運(yùn)行,而是指定Created狀態(tài)。接著調(diào)用Task類的Start()方法來啟動(dòng)任務(wù)。使用Task類時(shí),除了調(diào)用Start()方法,還可以調(diào)用RunSynchronously()方法。這樣,任務(wù)也會(huì)啟動(dòng),但是同時(shí)調(diào)用。默認(rèn)情況下,任務(wù)是異步運(yùn)行的。
Task類的構(gòu)造函數(shù)接收一個(gè)無參無返回值的委托:
1: Task task = new Task(TaskMethod); 2: task.Start();下面是TaskMethod方法:
1: static void TaskMethod() 2: { 3: for (int i = 0; i < 10; i++) 4: { 5: Console.WriteLine(String.Format("Running in a task. Task ID: {0}", Task.CurrentId)); 6: Thread.Sleep(500); 7: } 8: }方法里用Task.CurrentId屬性取得當(dāng)前任務(wù)ID。下面是主線程:
1: static void Main(string[] args) 2: { 3: Task task = new Task(TaskMethod); 4: task.Start(); 5:? 6: for (int i = 0; i < 10; i++) 7: { 8: Console.WriteLine("Running in main thread."); 9: Thread.Sleep(500); 10: } 11: 12: Console.Read(); 13: }如果要往線程里傳遞參數(shù),Task構(gòu)造函數(shù)提供的重載,可以傳入一個(gè)object類型的參數(shù):
1: Task task = new Task(TaskMethodWithParameter, "Hello world"); 2: task.Start();下面是帶參的線程方法:
1: static void TaskMethodWithParameter(object param) 2: { 3: for (int i = 0; i < 10; i++) 4: { 5: Console.WriteLine(String.Format("Running in a task. Parameter: {0}", param)); 6: Thread.Sleep(500); 7: } 8: }?
?
?
2、TaskFactory類
使用實(shí)例化的TaskFactory類,在其中把TaskMethod方法傳遞給StartNew()方法,就會(huì)立即啟動(dòng)任務(wù)。
1: TaskFactory tf = new TaskFactory(); 2: tf.StartNew(TaskMethod);?
?
?
3、Task.Factory屬性
Task類提供了一個(gè)Factory靜態(tài)屬性,這個(gè)屬性返回一個(gè)TaskFactory對象。
1: Task task = Task.Factory.StartNew(TaskMethod);?
?
?
后面的文章將介紹Task中的連續(xù)任務(wù)與層次任務(wù)
參考資料:《C#高級編程》,http://developer.51cto.com/art/200908/145541.htm
?
http://www.cnblogs.com/sosowjb/archive/2012/08/11/2633953.html
轉(zhuǎn)載于:https://www.cnblogs.com/jes_shaw/archive/2013/03/12/2956021.html
總結(jié)
以上是生活随笔為你收集整理的C#异步编程的实现方式(4)——Task任务的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 字符串匹配自动机
- 下一篇: mysql分表方法-----MRG_My