[問題] 有的 Thread 會裝死
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
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
01/21 21:05, 2F
→
01/21 21:05,
6年前
, 3F
01/21 21:05, 3F
是ㄟ @@ , 我以為其中一個執行完 , 下一個就能馬上拿到 lock @@
, 這塊觀念我再去加強一下 QQ
→
01/21 21:06,
6年前
, 4F
01/21 21:06, 4F
好的 , 非常感謝說明 @@y
※ 編輯: dnzteeqrq (220.135.182.159), 01/21/2018 21:34:39
推
01/24 17:49,
6年前
, 5F
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
01/27 01:56, 6F
推
02/06 14:37,
6年前
, 7F
02/06 14:37, 7F
java 近期熱門文章
PTT數位生活區 即時熱門文章