c# for循環中創建線程執行問題
先執行以一個簡單的示例:
static void Main(string[] args) { List<int> taskConsumes = new List<int>() { 1,2,3,4,5}; for (int i = 0; i < taskConsumes.Count; i++) { new Task(() => { TaskMethod(taskConsumes[i]); }).Start(); } Console.ReadLine(); } public static void TaskMethod(int index) { Console.WriteLine(index); }
執行結果:
直接異常瞭,按照常理不應該呀,我們再將原理的代碼改一下看看結果如何
我們先來創建執行線程代碼,然後在寫輸出代碼:
static void Main(string[] args) { new Task(() => { TaskMethod(1); }).Start(); Console.WriteLine("輸出內容"); Console.ReadLine(); }
輸出結果:
由此我們可以得出一個結論,就是:創建執行Task.Run()
是在另外一個子線程中執行的,他的創建+執行需要消耗一定的時間,而主線程方法是不會受Task的影響,他會直接執行
因此,我們最初的代碼中,for循環 0到taskConsumes.Count
,很快就會執行完成。當他執行完成最後的 i 其實不是taskConsumes.Count-1(
因為for是 i++形式),而是
所以,在執行子線程的時候,其實就是去拿taskConsumes[5
],準定就超出索引異常瞭。
那現在我們如果不想讓程序出錯的執行,給他改一下代碼:
static void Main(string[] args) { List<int> taskConsumes = new List<int>() { 1, 2, 3, 4, 5 }; for (int i = 0; i < taskConsumes.Count; i++) { int indexI = i; new Task(() => { TaskMethod(taskConsumes[indexI]); }).Start(); } Console.ReadLine(); }
執行結果:
這樣,我們在for中創建一個臨時變量indexI
,每個工作域中的i都賦予瞭局部變量indexI,Task中的變量就是局部變量indexI
瞭,而不是for
的全部變量i,程序也就達到瞭我們想要的效果瞭(另外Task子線程中執行順序也不是順序執行的)。
到此這篇關於c# for循環中創建線程執行問題的文章就介紹到這瞭,更多相關for循環中創建線程執行內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- .Net中Task Parallel Library的基本用法
- C#實現簡單學生成績管理系統
- C# List 並發丟數據問題原因及解決方案
- C#代碼延時的幾種實現
- c# Task.Wait()與awaiat Task異常處理的區別說明