Java使用Callable接口實現(xiàn)多線程的實例代碼
通過Callable接口實現(xiàn)多線程
實現(xiàn)Callable重寫call方法
實現(xiàn)Callable和實現(xiàn)Runnable類似,但是功能更強大,具體表現(xiàn)在
- 可以在任務結(jié)束后提供一個返回值,Runnable不行
- call方法可以拋出異常,Runnable的run方法不行
- 可以通過運行Callable得到的Fulture對象監(jiān)聽目標線程調(diào)用call方法的結(jié)果,得到返回值,(fulture.get(),調(diào)用后會阻塞,直到獲取到返回值)
1.Callable接口介紹:
(1)java.util.concurrent.Callable是一個泛型接口,只有一個call()方法
(2)call()方法拋出異常Exception異常,且返回一個指定的泛型類對象
2.Callable接口實現(xiàn)多線程的應用場景
當父線程想要獲取子線程的運行結(jié)果時
3.使用Callable接口實現(xiàn)多線程的步驟
(1)第一步:創(chuàng)建Callable子類的實例化對象
(2)第二步:創(chuàng)建FutureTask對象,并將Callable對象傳入FutureTask的構造方法中(注意:FutureTask實現(xiàn)了Runnable接口和Future接口)
(3)第三步:實例化Thread對象,并在構造方法中傳入FurureTask對象
(4)第四步:啟動線程
例1(利用Callable接口實現(xiàn)線程)
利用Callable接口創(chuàng)建子線程類:
package com.my.frame; import java.util.concurrent.Callable; public class ThreadCall implements Callable<String> { @Override public String call() throws Exception { // TODO Auto-generated method stub System.out.println("====="); return "9999"; } }
package com.my.frame; import java.util.concurrent.FutureTask; public class TestThread { public static void main(String[] args) { FutureTask<String> ft = new FutureTask<>(new ThreadCall()); new Thread(ft).start(); } }
例2(匿名類部類實現(xiàn)Callable接口創(chuàng)建子線程)
匿名類部類實現(xiàn)Callable接口創(chuàng)建子線程類并實現(xiàn):
package call; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; //匿名類部類實現(xiàn)Callable接口創(chuàng)建子線程 public class AnonyCallable { public static void main(String[] args) { Callable<String> cl = new Callable<String>() { @Override public String call() throws Exception { System.out.println(Thread.currentThread().getName() + "正在行軍~~~"); System.out.println(Thread.currentThread().getName() + "遭遇敵軍~~~"); System.out.println(Thread.currentThread().getName() + "奮勇殺敵?。。?!"); return "戰(zhàn)斗勝利,俘虜敵軍50000人"; } }; FutureTask<String> ft = new FutureTask(cl); new Thread(ft, "李存孝部隊").start(); try { Thread.currentThread().setName("李存勖部隊"); Thread.sleep(3000); System.out.println(Thread.currentThread().getName() + "休整3000ms"); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName() + "整頓完畢,等待友軍消息..."); try { String str = ft.get(); System.out.println("李存勖部隊得知友軍消息為:" + str); } catch (InterruptedException | ExecutionException e) { e.printStackTrace(); } } }
到此這篇關于Java使用Callable接口實現(xiàn)多線程的實例代碼的文章就介紹到這了,更多相關Java使用Callable接口實現(xiàn)多線程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- Java使用多線程批次查詢大量數(shù)據(jù)(Callable返回數(shù)據(jù))方式
- Java通過Callable實現(xiàn)多線程
- Java多線程中Callable和Future的解讀
- Java中的Callable實現(xiàn)多線程詳解
- Java多線程實現(xiàn)之Callable詳解
- Java中Runnable和Callable分別什么時候使用
- Java中Runnable與Callable接口的區(qū)別詳解
- 詳解Java中Callable和Future的區(qū)別
- Java使用Runnable和Callable實現(xiàn)多線程的區(qū)別詳解
- java面試常問的Runnable和Callable的區(qū)別
- Java并發(fā)教程之Callable和Future接口詳解
- Java中callable的實現(xiàn)原理
相關文章
Java異常處理之java.lang.ClassCastException問題
這篇文章主要介紹了Java異常處理之java.lang.ClassCastException問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07親測SpringBoot參數(shù)傳遞及@RequestBody注解---踩過的坑及解決
這篇文章主要介紹了親測SpringBoot參數(shù)傳遞及@RequestBody注解---踩過的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10Springbootadmin與security沖突問題及解決
這篇文章主要介紹了Springbootadmin與security沖突問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08