//callable 和 runnable的區(qū)別:
//runnable 的run方法不會有任何返回結果睦疫。所以祝線程無法獲得任務線程的返回值
//callable的call方法可以返回結果厘擂,但是主線程在獲取時是被阻塞的佩抹,需要等待任務線程返回才能拿到結果。
package threadimp;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class MyThreadCachePool {
public static void main(String[] args) {
ExecutorService pool = Executors.newCachedThreadPool();
for (int i = 0; i < 5; i++) {
pool.execute(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " start");
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
}
pool.shutdown();
}
}
package threadimp;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class MyThreadFixPoolCallable {
public static void main(String[] args) {
ExecutorService pool = Executors.newFixedThreadPool(4);
for (int i = 0; i < 8; i++) {
Future<String> result = pool.submit(new Callable<String>() {
@Override
public String call() {
System.out.println(Thread.currentThread().getName() + " start");
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return Thread.currentThread().getName();
}
});
try {
System.out.println(result.get());
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
pool.shutdown();
}
}
//result.get() 會阻塞!D匣骸扔嵌!
package threadimp;
import java.util.ArrayList;
import java.util.Random;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class TaskPool {
public static void main(String[] args) {
Future<?> submit = null;
Random random = new Random();
ExecutorService exec = Executors.newFixedThreadPool(4);
ArrayList<Future<?>> results = new ArrayList<>();
for (int i = 0; i < 10; i++) {
submit = exec.submit(new TaskCallable(i));
results.add(submit);
}
for (Future f: results) {
boolean done = f.isDone();
System.out.println(done);
try {
System.out.println("result " + f.get());
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
package threadimp;
import java.util.Random;
import java.util.concurrent.Callable;
public class TaskCallable implements Callable<String> {
private int s;
Random r = new Random();
public TaskCallable(int s) {
this.s = s;
}
@Override
public String call() {
int rand = r.nextInt(3);
String name = Thread.currentThread().getName();
System.out.println(name + " start");
try {
Thread.sleep(rand * 1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return name + " " + s;
}
}
thread pool
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扛拨,“玉大人耘分,你說我怎么就攤上這事“缶” “怎么了求泰?”我有些...
- 正文 為了忘掉前任卜朗,我火速辦了婚禮,結果婚禮上咕村,老公的妹妹穿的比我還像新娘场钉。我一直安慰自己,他們只是感情好培廓,可當我...
- 文/花漫 我一把揭開白布惹悄。 她就那樣靜靜地躺著,像睡著了一般肩钠。 火紅的嫁衣襯著肌膚如雪泣港。 梳的紋絲不亂的頭發(fā)上,一...
- 文/蒼蘭香墨 我猛地睜開眼箫柳,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了啥供?” 一聲冷哼從身側響起悯恍,我...
- 正文 年R本政府宣布榴嗅,位于F島的核電站妄呕,受9級特大地震影響,放射性物質發(fā)生泄漏嗽测。R本人自食惡果不足惜绪励,卻給世界環(huán)境...
- 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望唠粥。 院中可真熱鬧疏魏,春花似錦、人聲如沸晤愧。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽官份。三九已至只厘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間舅巷,已是汗流浹背羔味。 一陣腳步聲響...
推薦閱讀更多精彩內容
- thread pool hell this post content some of the basics of ...
- 問題背景 今天下午,突然收到nginx告警郵件,線上服務的web有N多的錯誤. 解決步驟 第一步 立馬保存現(xiàn)場, ...
- 更多 Java 并發(fā)編程方面的文章狠毯,請參見文集《Java 并發(fā)編程》 線程組 Thread Group 線程的集合...
- 1护糖、線程池作用 線程池作用就是限制系統(tǒng)中執(zhí)行線程的數量,且復用以前工作線程垃你。根據當前的環(huán)境椅文,手動配置線程池喂很,減少對...
- 使用Xcode 9之后發(fā)現(xiàn)控制臺一直在打印這個警告, 大致意思就是UI沒在主線程刷新 image.png 出現(xiàn)類似...