所以我試圖研究如何使用多線程,我注意到一些我不太明白的東西。在下一段代碼中,看起來 doo() 在 Thread 完成之前開始運行,盡管 foo 與 Thread 相同:static void Main(string[] args){ new Thread(new ThreadStart(foo)).Start(); foo(); doo();}public static void foo(){ Console.WriteLine("1"); Thread.Sleep(3000); Console.WriteLine("2");}public static void doo(){ Console.WriteLine("do");}輸出為:1 //線程1 //foo2 //foodo //doo2 //線程假設 doo() 在沒有 foo() 的情況下無法開始運行,我們假設最后一個“2”輸出來自第一個線程。這怎么可能?盡管 foo() 和 Thread 具有相同的休眠時間,因為它們是相同的函數,但為什么線程(首先執行)是最后一個完成的線程?鎖定語句現在,如果我們添加一個 lock 語句,如下所示:static object syncLock = new object();static void Main(string[] args){ new Thread(new ThreadStart(foo)).Start(); foo(); doo();}public static void foo(){ lock (syncLock) { Console.WriteLine("1"); Thread.Sleep(3000); Console.WriteLine("2"); } }public static void doo(){ Console.WriteLine("do");}輸出為:1 //線程2 //線程1 //foodo //doo2 //線程現在看起來 doo() 在 foo() 結束之前就開始運行了!這是怎么回事?過程及其背后的邏輯是什么?
1 回答

開心每一天1111
TA貢獻1836條經驗 獲得超13個贊
看,你在這里實際上有兩個線程,在主線程和第二個線程(foo())上。在 new Thread(new ThreadStart(foo)) 之后)。開始();執行將從主線程開始,這意味著這個線程(主線程)將嘗試調用foo(),即你的“1”,之后,主線程進入睡眠狀態,第二個線程star foo(),即第二個線程“1”,秒進入睡眠狀態?,F在主線程將喚醒并完成作業“2”,“do”,最后一個“2”來自sec線程。這是沒有鎖定的。
使用鎖定,主線程將執行 foo() 并且 sec 將被阻塞(“1”,3sec,“2”),當 foo() 解鎖時,這意味著,sec 線程可以調用 foo(),當發生這種情況時,sec 打印“1”廣告進入睡眠狀態,現在(當 sec 正在睡眠時 CPU 尋找可以執行的線程),因此 CPU 執行主線程并打印“do”,然后 sec 將喚醒并打印“2”。
- 1 回答
- 0 關注
- 90 瀏覽
添加回答
舉報
0/150
提交
取消