Java精選面試題(微信小程序):5000+道面試題和選擇題,真實面經,簡歷模版,包含Java基礎、并發、JVM、線程、MQ系列、Redis、Spring系列、Elasticsearch、Docker、K8s、Flink、Spark、架構設計、大廠真題等,在線隨時刷題!
之前紅包權益領取查詢的接口超時了,因為有用戶訂購的權益有點多。
解決方案
用線程池+ FutureTask將1個查詢拆分成多個小查詢 選擇FutureTask是因為它具有僅執行1次run()方法的特性(即使有多次調用也只執行1次),避免了重復查詢的可能。而且多任務異步執行也能提高接口響應速度。
本文主要講的是線程池搭配FutureTask異步執行的例子。
一、線程池+FutureTask執行多任務計算
public class Test { //線程池最好作為全局變量, 若作為局部變量記得用完后shutdown() ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-start-runner-%d").build(); ExecutorService taskExe= new ThreadPoolExecutor(10,20,800L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue ( 100),namedThreadFactory); int count=0; @Test public void test(String[] args) { //任務列表,公眾號:Java精選 List > taskList= new ArrayList >(); for(int i=0;i<100;i++){ //創建100個任務放入【任務列表】 FutureTask futureTask= new FutureTask ( new Callable () { @Override public Integer call() throws Exception { return1; } }); //執行的結果裝回原來的FutureTask中,后續直接遍歷集合taskList來獲取結果即可 taskList.add(futureTask); taskExe.submit(futureTask); } //獲取結果 try{ for(FutureTask futureTask:taskList){ count+=futureTask.get(); } } catch (InterruptedException e) { logger.error("線程執行被中斷",e); } catch (ExecutionException e) { logger.error("線程執行出現異常",e); } //關閉線程池 taskExe.shutdown(); //打印: 100 System.out.println(count); } }Callable接口能讓我們拿到線程的執行結果,所以讓它作為FutureTask構造函數FutureTask(Callable
callable)
的入參。
FutureTask執行的結果會放入它的私有變量outcome中,其他線程直接調用futureTask.get()去讀取該變量即可。另外,更多java面試題,公眾號Java精選,回復java面試,獲取面試資料。
二、子線程出的異常拋不出的情況
submit(Runnable task)提交任務的方式 ,是存在“隱患”的:
FutureTask內部的run()代碼塊會把異常給吞進去,通過setException(Throwable t)把異常賦給了對象outcome,我們在調用FutureTask.get()獲取結果的時候返回的就是這個對象
如果你的代碼沒有調用FutureTask.get(),它不會把異常吐出來,有可能子線程就莫名的停止了。
public Future submit(Runnable task) { if (task == null) throw new NullPointerException(); //創建一個異步執行的任務FutureTask, 【隱患】也在它的run()代碼塊里 RunnableFuture ftask = newTaskFor(task, null); execute(ftask); return ftask; }子線程創建之后會執行的是FutureTask內部的run()代碼塊,run()內部會有try-catch來截獲拋出的異常,將其賦值給對象outcome
上面的例子沒有這個問題,因為調用了FutureTask.get(),有異常會從這里拿出來。
作者:zhongh Jim
https://blog.csdn.net/qq_44384533/article/details/112324224
公眾號“Java精選”所發表內容注明來源的,版權歸原出處所有(無法查證版權的或者未注明出處的均來自網絡,系轉載,轉載的目的在于傳遞更多信息,版權屬于原作者。如有侵權,請聯系,筆者會第一時間刪除處理!
最近有很多人問,有沒有讀者交流群!加入方式很簡單,公眾號Java精選,回復“加群”,即可入群!
文章有幫助的話,點在看,轉發吧!
特別聲明:以上內容(如有圖片或視頻亦包括在內)為自媒體平臺“網易號”用戶上傳并發布,本平臺僅提供信息存儲服務。
Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.