作者woody3724 (woody)
看板java
標題[問題] 執行緒問題
時間Fri Mar 2 13:20:14 2018
目前在練習用多執行緒寫賽馬遊戲
將三匹馬放入三條執行緒中,看哪匹馬會先抵達終點
比賽過程以 for(int i=0; i<=200; i++); 表示
先讓整個for迴圈跑完的馬獲勝
並將比賽結果存入 List<String> rankList 之中
rankList.get(0)代表第一名
rankList.get(1)代表第二名
rankList.get(2)代表第三名
程式碼如下
https://paste.ofcode.org/KW9KFq4NnK9hrqgZrUk9VF
若把第10行註解起來,第11沒有註解,第44~45行的結果永遠會相同,如下圖
https://i.imgur.com/xjSQrE5.jpg
第一名永遠是horse1 第二名永遠是horse2 第三名永遠是horse3
請問為甚麼會這樣,執行續執行的順序不是應該是隨機的嗎?
但是若第10行沒註解,把第11行註解掉,則排名每次就會不同了,如下圖
https://i.imgur.com/H9c3cGO.jpg
這應該才是正常執行緒有的情況吧?
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 68.181.88.174
※ 文章網址: https://www.ptt.cc/bbs/java/M.1519968018.A.B82.html
→ LZN: 讓子彈飛久一點(誤) 03/02 14:49
→ LZN: 應該是thread處理的事情太少了, 把200改2000000看看 03/02 14:52
推 SolarKa5566: 同樓上,不然 for 迴圈塞一些麻煩的數學計算 03/02 15:09
→ SolarKa5566: 第10行應該是由於io比較花時間 03/02 15:09
推 zephyrhymn: 每個thread加個亂數迴圈就好 03/02 16:24
→ woody3724: 感謝大家,成功了!! 原來是for 迴圈做的事情太簡單了 03/03 05:44
→ pttworld: for迴圈簡單,可能牽扯compiler優化的問題。 03/03 20:23