|
自VS2010發(fā)布近半年了,雖然整天想學(xué)習(xí)新東西,要更新到自己時(shí),發(fā)現(xiàn)原來(lái)自己基本也很懶,2008還沒(méi)用上多久呢,無(wú)奈被2010了。用了幾天,IDE模樣還是和05、08差不多,加了些小特性,以后慢慢體驗(yàn)吧,第一感覺(jué)啟動(dòng)速度慢多了。主要還是.NET 4.0的變化,其實(shí)也就是修修補(bǔ)補(bǔ),語(yǔ)言特性幾乎沒(méi)什么新特性,C#多了個(gè)Dynamic,十年前VB就支持的晚綁定。只好把注意力放在了Framework上,新加的并行支持應(yīng)該是最大的變化吧。
VS2010發(fā)布會(huì)我也去過(guò)的,并行支持是一大賣(mài)點(diǎn)。當(dāng)時(shí)記得臺(tái)上一個(gè)MM對(duì)一個(gè)Linq查詢(xún)語(yǔ)句加了個(gè)ASParallel(),性能就神奇地提高了一倍,臺(tái)下掌聲雷動(dòng)。確實(shí)不費(fèi)吹灰之力提高程序性能,是最能引起大家興趣的。在看電子期刊時(shí),看到冷冷同學(xué),還有吳秦的文章,給偶這些菜鳥(niǎo)以震撼的啟發(fā),原來(lái)偶已經(jīng)遠(yuǎn)遠(yuǎn)落在了在讀大學(xué)生的后面。
那就開(kāi)始學(xué)吧,就拿Parallel開(kāi)刀。先抓個(gè)墊背的:
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; }
前面說(shuō)在練習(xí)Parallel時(shí),發(fā)現(xiàn)另有乾坤,是這樣的代碼:
static IEnumerable<Person> testFill(){ var list = new List<Person>(9); Enumerable.Range(1, 99999).ToList().ForEach(n => { var name = "Person" + n % 9; list.Add(new Person { Id = n, Name = name }); }); Console.WriteLine("Person's count is {0}", list.Count); return list;}static IEnumerable<Person> testFillParallel(){ var list = new List<Person>(9); Enumerable.Range(1, 99999).ASParallel().ForAll(n => { var name = "Person" + n % 9; list.Add(new Person { Id = n, Name = name }); }); Console.WriteLine("Person's count is {0}", list.Count); return list;}class Person{ internal int Id { get; set; } internal string Name { get; set; }}
接著上一次說(shuō),即使用了新的線程安全的集合BlockingCollection,這段代碼還是會(huì)有問(wèn)題。
static void testFillParallel(){ var list = new BlockingCollection<Person>(9999); Enumerable.Range(1, 99999).ASParallel().ForAll(n => { var name = "Person " + n % 9; if (list.Count(p => p.Name == name) < 1) list.Add(new Person { Id = n, Name = name }); }); Console.WriteLine("Person's count is {0}", list.Count);}
NET技術(shù):.Net 4.0并行庫(kù)實(shí)用性演練,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。