優秀同事昨天遇到一個問題:他寫的某個運算程式效率不如預期,由於有多個運算是可以獨立出來,再合併計算結果,因此他想用 Parallel.For 方法,可參考 撰寫簡單的 Parallel.For 迴圈。
但是這種方法其實比較麻煩,因為我很確定.Net的 Thread 會使用多顆核心,我建議他改用 Task,寫的時候切割比較方便。這裡簡單地說明一下 Task ,它是 .Net 4.0 以後引進,簡化 Thread 或 ThreadPool 寫法的新類別。想知道寫法可以看 黑暗大的 「簡介.NET 4.0的多工執行利器--Task」。
結果呢?優秀同事的程式快了7倍。
但是這種方法其實比較麻煩,因為我很確定.Net的 Thread 會使用多顆核心,我建議他改用 Task,寫的時候切割比較方便。這裡簡單地說明一下 Task ,它是 .Net 4.0 以後引進,簡化 Thread 或 ThreadPool 寫法的新類別。想知道寫法可以看 黑暗大的 「簡介.NET 4.0的多工執行利器--Task」。
結果呢?優秀同事的程式快了7倍。
留言