1. 程式人生 > 其它 >面試Java開發者時常問的15個Java多執行緒和併發問題

面試Java開發者時常問的15個Java多執行緒和併發問題

Java基礎是java初學者的起點,是幫助你從小白入門到精通必學基礎課程!

為初學者而著!

Java300集>>>適合準備入行開發的零基礎員學習Java,基於最新JDK13、IDEA平臺講解的,視訊中穿插多個實戰專案。每一個知識點都講解的通俗易懂,由淺入深。不僅適用於零基礎的初學者,有經驗的程式設計師也可做鞏固學習。

Java基礎板塊知識:

  1. 職業規劃
  2. 學習方法
  3. 泛型、容器
  4. 資料結構和演算法
  5. 智慧電話本實戰
  6. IO流
  7. Java介紹
  8. 變數、資料型別、運算子
  9. IDEA
  10. 控制語句、方法、遞迴演算法
  11. 面向物件
  12. JVM
  13. 陣列和資料儲存
  14. JDK
  15. 異常機制、視覺化
  16. 飛機大戰專案

配套學習:

Java初學者入門教程>>>

1. 現在有執行緒 T1、T2 和 T3。你如何確保 T2 執行緒在 T1 之後執行,並且 T3 執行緒在 T2 之後執行?

這個執行緒面試題通常在第一輪面試或電話面試時被問到,這道多執行緒問題為了測試面試者是否熟悉 join 方法的概念。答案也非常簡單——可以用 Thread 類的 join 方法實現這一效果。

2. Java 中新的 Lock 介面相對於同步程式碼塊(synchronized block)有什麼優勢?如果讓你實現一個高效能快取,支援併發讀取和單一寫入,你如何保證資料完整性。

多執行緒和併發程式設計中使用 lock 介面的最大優勢是它為讀和寫提供兩個單獨的鎖,可以讓你構建高效能資料結構,比如 ConcurrentHashMap 和條件阻塞。

這道 Java 執行緒面試題越來越多見,而且隨後的面試題都基於面試者對這道題的回答。

我強烈建議在任何 Java 多執行緒面試前都要多看看有關鎖的知識,因為如今電子交易系統的客戶端和資料互動中,鎖被頻繁使用來構建快取。

3. Java 中 wait 和 sleep 方法有什麼區別?

我們來看看另一個經常被問到的執行緒面試題。這道題常出現在電話面試中。兩者主要的區別就是等待釋放鎖和監視器。sleep方法在等待時不會釋放任何鎖或監視器。wait 方法多用於執行緒間通訊,而 sleep 只是在執行時暫停。可以看我另一篇有關Java 中 wait 和 sleep的文章。

4. 如何在 Java 中實現一個阻塞佇列?

這是一道相對困難的 Java 多執行緒面試題,考察點很多。它考察了面試者是否真正寫過 Java 多執行緒程式碼,考察了面試者對併發場景的理解。

並且可以根據面試者的程式碼問很多後續問題,如果他用 wait() 和 notify() 方法成功實現了阻塞佇列,可以讓他用 Java 5 的併發類重新實現一次。

5. 如何在 Java 中編寫程式碼解決生產者消費者問題?

答案和上面有關執行緒的問題相似,這個問題在工作中很典型,但有時面試官會問這類問題,比如“在 Java 中如何解決生產者消費者問題?”

其實,有很多解決方式。我分享過用 Java 中 BlockingQueue 的解決方案。有時他們甚至會讓你給出哲學家進餐問題的解決方案。

6. 寫一段死鎖程式碼。你在 Java 中如何解決死鎖?

這是我最喜歡的 Java 多執行緒面試題,因為即使死鎖在多執行緒併發程式設計中十分常見,許多面試者仍然抓耳撓腮,不能寫出無死鎖的程式碼。

只需要問他們如果有 N 個資源和 N 個執行緒去執行某個操作,然後請求所有資源。

這裡的 N 可以是 2 作為最簡單的情況,也可以是個很大的數字讓問題變複雜。

7. 什麼是原子操作?Java 中有哪些原子操作?

這是個簡單的 Java 執行緒面試題。另一個緊隨其後的問題將是:你需要同步原子操作嗎?

8. Java 中 volatile 關鍵字是什麼?你如何使用它?它和 Java 中的同步方法有什麼區別?

自從 Java 5 中調整 volatile 關鍵字和 Java 記憶體模型後,有關 volatile 關鍵字的執行緒問題越來越常見。掌握 volatile變數在併發環境中如何確保可見性、有序性和一致性非常重要。

9. 什麼是競態條件?你如何發現並解決競態條件?

這個 Java 多執行緒問題一般出現在高階面試。多數面試官會問你最近一次遇到的競態條件,如何解決的,有時他們也會寫點簡單程式碼讓你發現競態條件。

我認為,這是最棒的 Java 執行緒面試問題之一,而且可以測試出面試者解決競態條件的經驗,或是編寫無資料競爭、無其競態條件的程式碼經驗。

10. 在 Java 中你如何轉儲執行緒(thread dump)?如何分析它?

在 UNIX 中,你可以使用 kill -3 然後執行緒轉儲日誌會列印在螢幕上,可以使用 CTRL+Break 檢視。這只是一個較簡單的執行緒面試題,狡猾一點的話他們會問你如何分析轉儲日誌。執行緒轉儲日誌對於分析死鎖情況非常有用。

11. 既然 start() 方法會呼叫 run() 方法,為什麼我們呼叫 start() 方法,而不直接呼叫 run() 方法?

這是一個基本的 Java 多執行緒面試題。最初,我剛開始多執行緒程式設計時對此還有些困惑。如今我一般在 Java 中級面試的電話面試或一輪面試中遇到。

這道問題的答案是這樣的。當你呼叫 start() 方法時,它會新建一個執行緒然後執行 run() 方法中的程式碼。如果直接呼叫 run() 方法,並不會建立新執行緒,方法中的程式碼會在當前呼叫者的執行緒中執行

12. Java 中你如何喚醒阻塞執行緒?

這是有關執行緒的一個很狡猾的問題。有很多原因會導致阻塞,如果是 IO 阻塞,我認為沒有方式可以中斷執行緒(如果有的話請告訴我)。另一方面,如果執行緒阻塞是由於呼叫了 wait(),sleep() 或 join() 方法,你可以中斷執行緒,通過丟擲 InterruptedException 異常來喚醒該執行緒。

13. Java 中 CyclicBarriar 和 CountdownLatch 有什麼區別?

最近的 Java 執行緒面試題多數在測試你對 JDK 5 併發包的掌握程度。兩者區別之一就是CyclicBarrier 在屏障開啟之後(所有執行緒到達屏障點),可以重複使用。而 CountDownLatch 不行。

14. 什麼是不可變類?它對於編寫併發應用有何幫助?

儘管這道面試題和執行緒沒有直接關係,但間接影響也很大。如果面試官隨後讓你寫一個不可變類,或問你為什麼 Java 中的 String 是不可變的,會讓面試題變得更加複雜。

15. 你在多執行緒環境中遇到的最多的問題是什麼?你如何解決的?

記憶體干擾、競態條件、死鎖、活鎖、執行緒飢餓是多執行緒和併發程式設計中比較有代表性的問題。這類問題無休無止,而且難於定位和除錯。

想要學習更多的知識可以,工眾號:程式設計領域