.Net 4.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的例子說不定是被和諧過的,所以偶總會變變試驗過程。果然發現另有乾坤。
全站熱搜