您好,登錄后才能下訂單哦!
Java中怎么應用線程池,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
一 使用Future與Callable來計算斐波那契數(shù)列
1 代碼
import java.util.concurrent.*; public class FutureCallableDemo { static long fibonacci(long n) { if (n == 1 ||n == 2) return 1; else return fibonacci(n - 1) + fibonacci(n - 2); } public static void main( String[] args) throws Exception { Callable<Long> task = () -> fibonacci(30); ExecutorService executor = Executors.newFixedThreadPool(1); Future<Long> future = executor.submit(task); System.out.println("計算第10個斐波那契級數(shù),過會來取...") ; while (future.isDone() == false) { System.out.println("忙別的去吧,結(jié)果還在計算中...") ; } System.out.printf("計算完畢,第10個斐波那契級數(shù)是:%d %n", future.get()) ; } }
2 運行
計算第10個斐波那契級數(shù),過會來取...
忙別的去吧,結(jié)果還在計算中...
忙別的去吧,結(jié)果還在計算中...
忙別的去吧,結(jié)果還在計算中...
忙別的去吧,結(jié)果還在計算中...
忙別的去吧,結(jié)果還在計算中...
......
忙別的去吧,結(jié)果還在計算中...
計算完畢,第10個斐波那契級數(shù)是:832040
二 線程池模擬工人做工
1 代碼
import java.util.concurrent.Executors; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; class Task implements Runnable { private String name; public Task(String name) { this.name = name; } public String getName() { return name; } @Override public void run() { try { Long duration = (long) (Math.random() * 100); System.out.println("正在做工中,執(zhí)行者 : " + name); TimeUnit.SECONDS.sleep(duration); } catch (InterruptedException e) { e.printStackTrace(); } } } public class BasicThreadPoolExecutorExample { public static void main(String[] args) { ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newCachedThreadPool(); for (int i = 0; i <= 5; i++) { Task task = new Task("Task " + i); System.out.println("新任務添加成功 : " + task.getName()); executor.execute(task); } executor.shutdown(); } }
2 運行
新任務添加成功 : Task 0
新任務添加成功 : Task 1
新任務添加成功 : Task 2
新任務添加成功 : Task 3
新任務添加成功 : Task 4
新任務添加成功 : Task 5
正在做工中,執(zhí)行者 : Task 0
正在做工中,執(zhí)行者 : Task 3
正在做工中,執(zhí)行者 : Task 1
正在做工中,執(zhí)行者 : Task 2
正在做工中,執(zhí)行者 : Task 4
正在做工中,執(zhí)行者 : Task 5
Process finished with exit code 0
看完上述內(nèi)容,你們掌握Java中怎么應用線程池的方法了嗎?如果還想學到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。