[問題] 有的 Thread 會裝死

看板java作者 (過客)時間6年前 (2018/01/21 18:30), 6年前編輯推噓2(205)
留言7則, 4人參與, 6年前最新討論串1/1
public A extends Thread{ public static void main(String args[]){ List<Thread> threadList = new ArrayList<Thread>(); for (int i = 1; i <= 10 ; i++) { Thread t = new Thread(new A()); t.setPriority(Thread.MAX_PRIORITY); threadList.add(t); } for(Thread t:threadList){ t.start(); } } @Override public void run(){ for(int i=0;i<1000;i++){ // 使用 apache httpcomponents-client 套件 HttpClient client = HttpClientBuilder.create().build(); HttpGet request = new HttpGet(url); HttpResponse response; // 10 個 Thread 排隊發送 request synchronized (A.class) { response = client.execute(request); } ......... }//end for } } 目前遇到一個問題 , 一個 Thread 發送 1000 次 request , 一次執行 10 個 Thread , 每次執行固定會有2個大幅落後其他8個 , 這 8 個 大概同時執行完畢 , 但另外 2 個可能只執行到 500 次 左右 , 謂何有 2 個 Thread 好像搶不到資源的樣子 , 照理說會照 排隊一個一個處理才是 ,應該不至於差這麼多 冏rz 後來有設定優先順序 , 10 個 Thread 都設最高 、 也有設定記憶體 -Xmx=2500m , 結果還是一樣 0rz 有沒有高手幫忙解答一下 >.< -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 220.135.182.159 ※ 文章網址: https://www.ptt.cc/bbs/java/M.1516530638.A.19F.html ※ 編輯: dnzteeqrq (220.135.182.159), 01/21/2018 20:29:09

01/21 20:58, 6年前 , 1F
照理說會排隊? 是照什麼理? synchronized不保證照順序
01/21 20:58, 1F
以前單核心 時 , D C B A , A 先執行完 換 B 這樣 當然有可能 B 比 A 更快處理完畢 變成 A B D C 當然如果優先順序等級不一樣就會看誰的設定等級高 @@a (以前單核心 也想說不管順序 A B C D 一起搶 看誰搶到誰執行 , 不過得到的結果是 優先順序一樣 , 就先進先出 ) 不過現在多核心 , 優先等級都一樣分配的機率應該不會差太多 , 可是每次 就會固定有 2 個 慢別人一半 @@a 還是我的觀念有誤嗎 ? ※ 編輯: dnzteeqrq (220.135.182.159), 01/21/2018 21:18:13

01/21 21:05, 6年前 , 2F
有分到CPU的thread連搶很多次lock,而沒有分到CPU的thread
01/21 21:05, 2F

01/21 21:05, 6年前 , 3F
過一段時間才能試一次是很可能發生的,你的CPU是8 thread?
01/21 21:05, 3F
是ㄟ @@ , 我以為其中一個執行完 , 下一個就能馬上拿到 lock @@ , 這塊觀念我再去加強一下 QQ

01/21 21:06, 6年前 , 4F
要保證排隊需要有個Queue去實作
01/21 21:06, 4F
好的 , 非常感謝說明 @@y ※ 編輯: dnzteeqrq (220.135.182.159), 01/21/2018 21:34:39

01/24 17:49, 6年前 , 5F
迴圈加個sleep是不是比較不會卡住
01/24 17:49, 5F
我有試著在synchronized一解鎖後就 sleep 50 毫秒 , 結果差不多 @@ ,不過拿掉synchronized , 10個大概同時執行完畢(沒有sleep) ,想不到 lock 影響這麼大 ※ 編輯: dnzteeqrq (220.135.182.159), 01/24/2018 20:53:47

01/27 01:56, 6年前 , 6F
thread starvation
01/27 01:56, 6F
感謝說明 ^q^ https://goo.gl/9ujwb8 ※ 編輯: dnzteeqrq (1.168.21.65), 01/27/2018 12:08:57

02/06 14:37, 6年前 , 7F
喔喔喔 (筆記
02/06 14:37, 7F
文章代碼(AID): #1QP6lE6V (java)