在任何Java面試當中多線程和併發方面的問題都是必不可少的一部分。若是你想得到任何股票投資銀行的前臺資訊職位,那麼你應該準備不少關於多線程的問題。在投資銀行業務中多線程和併發是一個很是受歡迎的話題,特別是電子交易發展方面相關的。他們會問面試者不少使人混淆的Java線程問題。面試官只是想確信面試者有足夠的Java線程與併發方面的知識,由於候選人中有不少只浮於表面。用於直接面向市場交易的高容量和低延時的電子交易系統在本質上是併發的。下面這些是我在不一樣時間不一樣地點喜歡問的Java線程問題。我沒有提供答案,但只要可能我會給你線索,有些時候這些線索足夠回答問題。如今引用Java5併發包關於併發工具和併發集合的問題正在增多。那些問題中ThreadLocal、Blocking Queue、Counting Semaphore和ConcurrentHashMap比較流行。java
15個Java多線程面試題及回答
面試
1)如今有T一、T二、T3三個線程,你怎樣保證T2在T1執行完後執行,T3在T2執行完後執行?算法
這個線程問題一般會在第一輪或電話面試階段被問到,目的是檢測你對」join」方法是否熟悉。這個多線程問題比較簡單,能夠用join方法實現。編程
2)在Java中Lock接口比synchronized塊的優點是什麼?你須要實現一個高效的緩存,它容許多個用戶讀,但只容許一個用戶寫,以此來保持它的完整性,你會怎樣去實現它?windows
lock接口在多線程和併發編程中最大的優點是它們爲讀和寫分別提供了鎖,它能知足你寫像ConcurrentHashMap這樣的高性能數據結構和有條件的阻塞。Java線程面試的問題愈來愈會根據面試者的回答來提問。我強烈建議在你去參加多線程的面試以前認真讀一下Locks,由於當前其大量用於構建電子交易終統的客戶端緩存和交易鏈接空間。緩存
3)在java中wait和sleep方法的不一樣?數據結構
一般會在電話面試中常常被問到的Java線程面試問題。最大的不一樣是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait一般被用於線程間交互,sleep一般被用於暫停執行。多線程
4)用Java實現阻塞隊列。併發
這是一個相對艱難的多線程面試問題,它能達到不少的目的。第一,它能夠檢測侯選者是否能實際的用Java線程寫程序;第二,能夠檢測侯選者對併發場景的理解,而且你能夠根據這個問不少問題。若是他用wait()和notify()方法來實現阻塞隊列,你能夠要求他用最新的Java 5中的併發類來再寫一次。框架
5)用Java寫代碼來解決生產者——消費者問題。
與上面的問題很相似,但這個問題更經典,有些時候面試都會問下面的問題。在Java中怎麼解決生產者——消費者問題,固然有不少解決方法,我已經分享了一種用阻塞隊列實現的方法。有些時候他們甚至會問怎麼實現哲學家進餐問題。
6)用Java編程一個會致使死鎖的程序,你將怎麼解決?
這是我最喜歡的Java線程面試問題,由於即便死鎖問題在寫多線程併發程序時很是廣泛,可是不少侯選者並不能寫deadlock free code(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個資源和N個線程,而且你須要全部的資源來完成一個操做。爲了簡單這裏的n能夠替換爲2,越大的數據會使問題看起來更復雜。經過避免Java中的死鎖來獲得關於死鎖的更多信息。
7) 什麼是原子操做,Java中的原子操做是什麼?
很是簡單的java線程面試問題,接下來的問題是你須要同步一個原子操做。
8) Java中的volatile關鍵是什麼做用?怎樣使用它?在Java中它跟synchronized方法有什麼不一樣?
自從Java 5和Java內存模型改變之後,基於volatile關鍵字的線程問題愈來愈流行。應該準備好回答關於volatile變量怎樣在併發環境中確保可見性、順序性和一致性。
9) 什麼是競爭條件?你怎樣發現和解決競爭?
這是一道出如今多線程面試的高級階段的問題。大多數的面試官會問最近你遇到的競爭條件,以及你是怎麼解決的。有些時間他們會寫簡單的代碼,而後讓你檢測出代碼的競爭條件。能夠參考我以前發佈的關於Java競爭條件的文章。在我看來這是最好的java線程面試問題之一,它能夠確切的檢測候選者解決競爭條件的經驗,or writing code which is free of data race or any other race condition。關於這方面最好的書是《Concurrency practices in Java》。
10) 你將如何使用thread dump?你將如何分析Thread dump?
在UNIX中你可使用kill -3,而後thread dump將會打印日誌,在windows中你可使用」CTRL+Break」。很是簡單和專業的線程面試問題,可是若是他問你怎樣分析它,就會很棘手。
11) 爲何咱們調用start()方法時會執行run()方法,爲何咱們不能直接調用run()方法?
這是另外一個很是經典的java多線程面試問題。這也是我剛開始寫線程程序時候的困惑。如今這個問題一般在電話面試或者是在初中級Java面試的第一輪被問到。這個問題的回答應該是這樣的,當你調用start()方法時你將建立新的線程,而且執行在run()方法裏的代碼。可是若是你直接調用run()方法,它不會建立新的線程也不會執行調用線程的代碼。閱讀我以前寫的《start與run方法的區別》這篇文章來得到更多信息。
12) Java中你怎樣喚醒一個阻塞的線程?
這是個關於線程和阻塞的棘手的問題,它有不少解決方法。若是線程遇到了IO阻塞,我而且不認爲有一種方法能夠停止線程。若是線程由於調用wait()、sleep()、或者join()方法而致使的阻塞,你能夠中斷線程,而且經過拋出InterruptedException來喚醒它。我以前寫的《How to deal with blocking methods in java》有不少關於處理線程阻塞的信息。
13)在Java中CycliBarriar和CountdownLatch有什麼區別?
這個線程問題主要用來檢測你是否熟悉JDK5中的併發包。這兩個的區別是CyclicBarrier能夠重複使用已經經過的障礙,而CountdownLatch不能重複使用。
14) 什麼是不可變對象,它對寫併發應用有什麼幫助?
另外一個多線程經典面試問題,並不直接跟線程有關,但間接幫助不少。這個java面試問題能夠變的很是棘手,若是他要求你寫一個不可變對象,或者問你爲何String是不可變的。
15) 你在多線程環境中遇到的共同的問題是什麼?你是怎麼解決它的?
多線程和併發程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和飢餓。問題是沒有止境的,若是你弄錯了,將很難發現和調試。這是大多數基於面試的,而不是基於實際應用的Java線程問題。
補充的其它幾個問題:
1) 在java中綠色線程和本地線程區別?
2) 線程與進程的區別?
3) 什麼是多線程中的上下文切換?
4)死鎖與活鎖的區別,死鎖與餡餅的區別?
5) Java中用到的線程調度算法是什麼?
6) 在Java中什麼是線程調度?
7) 在線程中你怎麼處理不可捕捉異常?
8) 什麼是線程組,爲何在Java中不推薦使用?
9) 爲何使用Executor框架比使用應用建立和管理線程好?
10) 在Java中Executor和Executors的區別?
11) 如何在Windows和Linux上查找哪一個線程使用的CPU時間最長?