.Net 4.0并行庫實用性演練

作者: XiaoMing  發布時間: 2010-09-14 12:59  閱讀: 3032 次  推薦: 0   原文鏈接   [收藏]  
 
摘要:文中作者深入淺出的介紹了.Net4.0的并行編程,利用.Net 4.0的并行庫實際編寫了幾段代碼,供大家學習參考。
[1] .Net 4.0并行庫實用性演練
[2] .Net 4.0并行庫實用性演練
[3] .Net 4.0并行庫實用性演練

  自VS2010發布近半年了,雖然整天想學習新東西,要更新到自己時,發現原來自己基本也很懶,2008還沒用上多久呢,無奈被2010了。用了幾天,IDE模樣還是和05、08差不多,加了些小特性,以后慢慢體驗吧,第一感覺啟動速度慢多了。主要還是.Net 4.0的變化,其實也就是修修補補,語言特性幾乎沒什么新特性,C#多了個Dynamic,十年前VB就支持的晚綁定。只好把注意力放在了Framework上,新加的并行支持應該是最大的變化吧。

  VS2010發布會我也去過的,并行支持是一大賣點。當時記得臺上一個MM對一個Linq查詢語句加了個AsParallel(),性能就神奇地提高了一倍,臺下掌聲雷動。確實不費吹灰之力提高程序性能,是最能引起大家興趣的。在看電子期刊時,看到冷冷同學,還有吳秦的文章,給偶這些菜鳥以震撼的啟發,原來偶已經遠遠落在了在讀大學生的后面。

  那就開始學吧,就拿Parallel開刀。先抓個墊背的:

static void Set(int length)
        {
            var array = new int[length, length, length];
            for (int i = 0; i < length; i++)
                for (int j = 0; j < length; j++)
                    for (int k = 0; k < length; k++)
                        array[i, j, k] = System.Threading.Thread.CurrentThread.ManagedThreadId;
        }

再請出真神:

 static void ParallelSet(int length)
        {
            var array = new int[length, length, length];
            Parallel.For(0, length, i =>
            {
                for (int j = 0; j < length; j++)
                    for (int k = 0; k < length; k++)
                        array[i, j, k] = System.Threading.Thread.CurrentThread.ManagedThreadId;
            });
        }

PK:

CodeTimer.Time("Single thread", 100, () => Set(100));
CodeTimer.Time("Multiple thread", 100, () => ParallelSet(100));

結果,1136ms:729ms,果然不錯。不過MSDN的例子說不定是被和諧過的,所以偶總會變變試驗過程。果然發現另有乾坤。

0
0
 
標簽:.Net 并行庫
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()