日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
.NET 4并行編程之Task基礎(chǔ)部分完結(jié)篇

查看本系列其他文章,請參看

成都一家集口碑和實力的網(wǎng)站建設(shè)服務(wù)商,擁有專業(yè)的企業(yè)建站團隊和靠譜的建站技術(shù),10年企業(yè)及個人網(wǎng)站建設(shè)經(jīng)驗 ,為成都近1000家客戶提供網(wǎng)頁設(shè)計制作,網(wǎng)站開發(fā),企業(yè)網(wǎng)站制作建設(shè)等服務(wù),包括成都營銷型網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),同時也為不同行業(yè)的客戶提供網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計的服務(wù),包括成都電商型網(wǎng)站制作建設(shè),裝修行業(yè)網(wǎng)站制作建設(shè),傳統(tǒng)機械行業(yè)網(wǎng)站建設(shè),傳統(tǒng)農(nóng)業(yè)行業(yè)網(wǎng)站制作建設(shè)。在成都做網(wǎng)站,選網(wǎng)站制作建設(shè)服務(wù)商就選創(chuàng)新互聯(lián)公司。

[[11863]]

本篇的主要議題如下:

1.獲取Task的狀態(tài)

2.執(zhí)行晚加載的Task(Lazily Task)

3.常見問題的解決方案

1.獲取Task的狀態(tài)

在.NET并行編程還有一個已經(jīng)標(biāo)準(zhǔn)化的操作就是可以獲取task的狀態(tài),通過Task.Status屬性來得到的,這個屬性返回一個System.Threading.Tasks.TaskStatus的枚舉值。

如下:

Created:表明task已經(jīng)被初始化了,但是還沒有加入到Scheduler中。

WatingForActivation:task正在等待被加入到Scheduler中。

 WaitingToRun:已經(jīng)被加入到了Scheduler,等待執(zhí)行。

Running:task正在運行

WaitingForChildrenToComplete:表明父task正在等待子task運行結(jié)束。

RanToCompletion:表明task已經(jīng)執(zhí)行完了,但是還沒有被cancel,而且也這個task也沒有拋出異常。

Canceled:表明task已經(jīng)被cancel了。(大家可以參看之前講述取消task的文章)

Faulted:表明task在運行的時候已經(jīng)拋出了異常。

2.執(zhí)行晚加載的Task(Lazily Task)

晚加載,或者又名延遲初始化,主要的好處就是避免不必要的系統(tǒng)開銷。在并行編程中,可以聯(lián)合使用Lazy變量和Task<>.Factory.StartNew()做到這點。(Lazy變量時.NET 4中的一個新特性,這里大家不用知道Lazy的具體細(xì)節(jié))

Lazy變量只有在用到的時候才會被初始化。所以我們可以把Lazy變量和task的創(chuàng)建結(jié)合:只有這個task要被執(zhí)行的時候才去初始化。

下面還是通過例子來講解:

代碼 

 
 
 
  1. static void Main(string[] args)  
  2.        {  
  3.            // define the function  
  4.            Func taskBody = new Func(() =>  
  5.            {  
  6.                Console.WriteLine("Task body working...");  
  7.                return "Task Result";  
  8.            });  
  9.  
  10.            // create the lazy variable  
  11.            Lazy> lazyData = new Lazy>(() =>  
  12.            Task.Factory.StartNew(taskBody));  
  13.  
  14.            Console.WriteLine("Calling lazy variable");  
  15.            Console.WriteLine("Result from task: {0}", lazyData.Value.Result);  
  16.  
  17.            // do the same thing in a single statement  
  18.            Lazy> lazyData2 = new Lazy>(  
  19.            () => Task.Factory.StartNew(() =>  
  20.            {  
  21.                Console.WriteLine("Task body working...");  
  22.                return "Task Result";  
  23.            }));  
  24.  
  25.            Console.WriteLine("Calling second lazy variable");  
  26.            Console.WriteLine("Result from task: {0}", lazyData2.Value.Result);  
  27.  
  28.            // wait for input before exiting  
  29.            Console.WriteLine("Main method complete. Press enter to finish.");  
  30.            Console.ReadLine();  
  31.        } 

首先我們回想一下,在之前的系列文章中我們是怎么定義一個task的:直接new,或者通過task的factory來創(chuàng)建,因為創(chuàng)建task的代碼是在main函數(shù)中的,所以只要new了一個task,那么這個task就被初始化。現(xiàn)在如果用了Lazy的task,那么現(xiàn)在我們初始化的就是那個Lazy變量了,而沒有初始化task,(初始化Lazy變量的開銷小于初始化task),只有當(dāng)調(diào)用了lazyData.Value時,Lazy變量中包含的那個task才會初始化。(這里歡迎大家提出自己的理解)

3.常見問題的解決方案

a.Task 死鎖

描述:如果有兩個或者多個task(簡稱TaskA)等待其他的task(TaskB)執(zhí)行完成才開始執(zhí)行,但是TaskB也在等待TaskA執(zhí)行完成才開始執(zhí)行,這樣死鎖就產(chǎn)生了。

解決方案:避免這個問題最好的方法就是:不要使的task來依賴其他的task。也就是說,最好不要你定義的task的執(zhí)行體內(nèi)包含其他的task。

例子:在下面的例子中,有兩個task,他們相互依賴:他們都要使用對方的執(zhí)行結(jié)果。當(dāng)主程序開始運行之后,兩個task也開始運行,但是因為兩個task已經(jīng)死鎖了,所以主程序就一直等待。

代碼

 
 
 
  1. static void Main(string[] args)  
  2.         {  
  3.             // define an array to hold the Tasks  
  4.             Task[] tasks = new Task[2];  
  5.  
  6.             // create and start the first task  
  7.             tasks[0] = Task.Factory.StartNew(() =>  
  8.             {  
  9.                 // get the result of the other task,  
  10.                 // add 100 to it and return it as the result  
  11.                 return tasks[1].Result + 100;  
  12.             });  
  13.  
  14.             // create and start the second task  
  15.             tasks[1] = Task.Factory.StartNew(() =>  
  16.             {  
  17.                 // get the result of the other task,  
  18.                 // add 100 to it and return it as the result  
  19.                 return tasks[1].Result + 100;  
  20.             });  
  21.  
  22.  
  23.             // wait for the tasks to complete  
  24.             Task.WaitAll(tasks);  
  25.  
  26.             // wait for input before exiting  
  27.             Console.WriteLine("Main method complete. Press enter to finish.");  
  28.             Console.ReadLine();  
  29.         } 

本篇就到這里了,很短,基礎(chǔ)的部分就基本介紹完了,后面的文章就開始講述應(yīng)用。


網(wǎng)站欄目:.NET 4并行編程之Task基礎(chǔ)部分完結(jié)篇
文章位置:http://www.dlmjj.cn/article/dpesepp.html