首页
/
每日頭條
/
職場
/
自己設計線程池要從哪些方面考慮
自己設計線程池要從哪些方面考慮
更新时间:2025-07-12 08:34:49

  面試題1:ThreadPoolExecutor 有哪些常用的方法?

  ThreadPoolExecutor有如下常用方法:

  submit()/execute():執行線程池shutdown()/shutdownNow():終止線程池isShutdown():判斷線程是否終止getActiveCount():正在運行的線程數getCorePoolSize():獲取核心線程數getMaximumPoolSize():獲取最大線程數getQueue():獲取線程池中的任務隊列allowCoreThreadTimeOut(boolean):設置空閑時是否回收核心線程 這些方法可以用來終止線程池、線程池監控等。

  面試題2:說說submit(和 execute兩個方法有什麼區别?

  submit() 和 execute() 都是用來執行線程池的,隻不過使用 execute() 執行線程池不能有返回方法,而使用 submit() 可以使用 Future 接收線程池執行的返回值。

  面試題3:shutdownNow() 和 shutdown() 兩個方法有什麼區别?

  shutdownNow() 和 shutdown() 都是用來終止線程池的,它們的區别是,使用 shutdown() 程序不會報錯,也不會立即終止線程,它會等待線程池中的緩存任務執行完之後再退出,執行了 shutdown() 之後就不能給線程池添加新任務了;shutdownNow() 會試圖立馬停止任務,如果線程池中還有緩存任務正在執行,則會抛出 java.lang.InterruptedExceptIOn: sleep interrupted 異常。

  面試題4:了解過線程池的工作原理嗎?

  自己設計線程池要從哪些方面考慮(線程池必須要會的10道面試題)(1)

  當線程池中有任務需要執行時,線程池會判斷如果線程數量沒有超過核心數量就會新建線程池進行任務執行,如果線程池中的線程數量已經超過核心線程數,這時候任務就會被放入任務隊列中排隊等待執行;如果任務隊列超過最大隊列數,并且線程池沒有達到最大線程數,就會新建線程來執行任務;如果超過了最大線程數,就會執行拒絕執行策略。

  面試題5:線程池中核心線程數量大小怎麼設置?

  「CPU密集型任務」:比如像加解密,壓縮、計算等一系列需要大量耗費 CPU 資源的任務,大部分場景下都是純 CPU 計算。盡量使用較小的線程池,一般為CPU核心數 1。因為CPU密集型任務使得CPU使用率很高,若開過多的線程數,會造成CPU過度切換。

  「IO密集型任務」:比如像 MySQL 數據庫、文件的讀寫、網絡通信等任務,這類任務不會特别消耗 CPU 資源,但是 IO 操作比較耗時,會占用比較多時間。可以使用稍大的線程池,一般為2*CPU核心數。IO密集型任務CPU使用率并不高,因此可以讓CPU在等待IO的時候有其他線程去處理别的任務,充分利用CPU時間。

  另外:線程的平均工作時間所占比例越高,就需要越少的線程;線程的平均等待時間所占比例越高,就需要越多的線程;

  以上隻是理論值,實際項目中建議在本地或者測試環境進行多次調優,找到相對理想的值大小。

  面試題6:線程池為什麼需要使用(阻塞)隊列?

  主要有三點:

  因為線程若是無限制的創建,可能會導緻内存占用過多而産生OOM,并且會造成cpu過度切換。創建線程池的消耗較高。 面試題7:線程池為什麼要使用阻塞隊列而不使用非阻塞隊列?

  阻塞隊列可以保證任務隊列中沒有任務時阻塞獲取任務的線程,使得線程進入wait狀态,釋放cpu資源。

  當隊列中有任務時才喚醒對應線程從隊列中取出消息進行執行。

  使得在線程不至于一直占用cpu資源。

  (線程執行完任務後通過循環再次從任務隊列中取出任務進行執行,代碼片段如下

  while (task != null || (task = getTask()) != null) {})。

  不用阻塞隊列也是可以的,不過實現起來比較麻煩而已,有好用的為啥不用呢?

  面試題8:了解線程池狀态嗎?

  通過獲取線程池狀态,可以判斷線程池是否是運行狀态、可否添加新的任務以及優雅地關閉線程池等。

  自己設計線程池要從哪些方面考慮(線程池必須要會的10道面試題)(2)

  RUNNING:線程池的初始化狀态,可以添加待執行的任務。SHUTDOWN:線程池處于待關閉狀态,不接收新任務僅處理已經接收的任務。STOP:線程池立即關閉,不接收新的任務,放棄緩存隊列中的任務并且中斷正在處理的任務。TIDYING:線程池自主整理狀态,調用 terminated() 方法進行線程池整理。TERMINATED:線程池終止狀态。 面試題9:知道線程池中線程複用原理嗎?

  線程池将線程和任務進行解耦,線程是線程,任務是任務,擺脫了之前通過 Thread 創建線程時的一個線程必須對應一個任務的限制。

  在線程池中,同一個線程可以從阻塞隊列中不斷獲取新任務來執行,其核心原理在于線程池對 Thread 進行了封裝,并不是每次執行任務都會調用 Thread.start() 來創建新線程,而是讓每個線程去執行一個“循環任務”,在這個“循環任務”中不停的檢查是否有任務需要被執行,如果有則直接執行,也就是調用任務中的 run 方法,将 run 方法當成一個普通的方法執行,通過這種方式将隻使用固定的線程就将所有任務的 run 方法串聯起來。

  面試題10:說說線程池創建需要的那幾個核心參數的含義

  ThreadPoolExecutor 最多包含以下七個參數:

  corePoolSize:線程池中的核心線程數maximumPoolSize:線程池中最大線程數keepAliveTime:閑置超時時間unit:keepAliveTime 超時時間的單位(時/分/秒等)workQueue:線程池中的任務隊列threadFactory:為線程池提供創建新線程的線程工廠rejectedExecutionHandler:線程池任務隊列超過最大值之後的拒絕策略總結 本文通過沒有使用線程池帶來的弊端,Executors介紹,Executors的六種方法介紹、如何使用線程池,了解線程池原理,核心參數,以及10到線程池面試題。

  「成功不是将來才有的,而是從決定去做的那一刻起,持續累積而成。」

  ,

Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
電商運營的工作業績(做任務領獎賞協同辦公應用)
電商運營的工作業績(做任務領獎賞協同辦公應用)
     似乎很多人都觊觎協同辦公這一領域,在他們看來,主要原因是現在的同類産品并沒有提出很好的解決方案。   我曾經寫過幾個此款産品,也一直是這類産品的忠實用戶。但當工作趣的負責人向我介紹其産品時,我還是有眼前一亮的感覺。   工作趣允許用戶在發布一條任務時,附帶獎勵。 舉例來說,BOSS 将“采訪工作趣創始人”的任務分配給我,随即附帶了“獎勵 500 元...
2025-07-12
便攜制氧機(一文講解便攜式制氧機如何工作)
便攜制氧機(一文講解便攜式制氧機如何工作)
  便攜式制氧機可在各種不同的環境中提供補充氧氣,無論是在家中還是在旅途中。有兩種類型的便攜式制氧機:連續流量和脈沖劑量。   連續流便攜式氧氣濃縮器連續流制氧機以恒定速率輸送氧氣,無需注意吸氣或呼氣。這種模式允許氧氣也連接到PAP 機器。由于氧氣是恒定的,設備使用更多的電池電量。這些機器通常尺寸大一些,可以提供更高的氧氣需求。   注意:并非所有便攜式制氧...
2025-07-12
41歲女老闆和小男友見面(外國男子向女老闆表白)
41歲女老闆和小男友見面(外國男子向女老闆表白)
  愛情這種東西很奇妙,在旁人的眼裡并不看好,但偏偏卻愛着如膝似歡。   或許隻有當局者才能知道對方對自己的感情。   近日,在廣東廣州一間經營茶葉的店鋪裡面,一名外國男子捧着黃色玫瑰花單腳下跪向這間店鋪的女老闆表白,在表白的過程當中,這名外國男子不斷用英語反複在說,你願意嫁給我嗎?   這位女老闆被突如其來的一面吓着了,她害羞低下頭并收下這名男子的花朵。 ...
2025-07-12
職業性肺病及其他呼吸道疾病(職業性肺病的分類及其影像學表現)
職業性肺病及其他呼吸道疾病(職業性肺病的分類及其影像學表現)
     導語   職業性肺病是指在生産過程中,因接觸職業病危害因素産生以呼吸道及肺部損傷為主的疾病。職業性肺病依然是我國嚴重的職業病,影像學檢查在職業性肺病的診斷和監測中起着重要作用,本文介紹了其影像學表現。   分類   目前我國職業性塵肺病及其他呼吸系統疾病共有19種,包括塵肺病13種 (矽肺、煤工塵肺、石墨塵肺、碳黑塵肺、石棉肺、滑石塵肺、水泥塵肺、...
2025-07-12
魔獸世界冰法新天賦怎麼點(8.0魔獸世界冰法職業)
魔獸世界冰法新天賦怎麼點(8.0魔獸世界冰法職業)
  本文是對8.0版本冰法的詳細分析和結論分享。   一、關于天賦的分析和選擇刺骨冰寒/孤寂寒冬/寒冰新星   所有帶減速效果的技能每擊中一個敵人都可以疊加一層效果,疊滿10層獲得5%的法傷,是非熱能體系的最優解。   單體戰鬥隻有寒冰箭,冰槍術,冰風暴總占比超過55%的場景才能穩定超過刺骨冰寒,多目标戰鬥也需要最少45%。   能額外提供一個最少持續1秒的...
2025-07-12
Copyright 2023-2025 - www.tftnews.com All Rights Reserved