- 相關推薦
多線程編程面試題
在任何Java面試當中多線程和并發(fā)方面的問題都是必不可少的一部分。如果你想獲得任何股票投資銀行的前臺資訊職位,那么你應該準備很多關于多線程的問題。在投資銀行業(yè)務中多線程和并發(fā)是一個非常受歡迎的話題,特別是電子交易發(fā)展方面相關的。他們會問面試者很多令人混淆的Java線程問題。面試官只是想確信面試者有足夠的Java線程與并發(fā)方面的知識,因為候選人中有很多只浮于表面。用于直接面向市場交易的高容量和低延時的電子交易系統(tǒng)在本質(zhì)上是并發(fā)的。下面這些是我在不同時間不同地點喜歡問的Java線程問題。我沒有提供答案,但只要可能我會給你線索,有些時候這些線索足夠回答問題,F(xiàn)在引用Java5并發(fā)包關于并發(fā)工具和并發(fā)集合的問題正在增多。那些問題中ThreadLocal、Blocking Queue、Counting Semaphore和ConcurrentHashMap比較流行。
15個Java多線程面試題及回答
1)現(xiàn)在有T1、T2、T3三個線程,你怎樣保證T2在T1執(zhí)行完后執(zhí)行,T3在T2執(zhí)行完后執(zhí)行?
這個線程問題通常會在第一輪或電話面試階段被問到,目的是檢測你對”join”方法是否熟悉。這個多線程問題比較簡單,可以用join方法實現(xiàn)。
2)在Java中Lock接口比synchronized塊的優(yōu)勢是什么?你需要實現(xiàn)一個高效的緩存,它允許多個用戶讀,但只允許一個用戶寫,以此來保持它的完整性,你會怎樣去實現(xiàn)它?
lock接口在多線程和并發(fā)編程中最大的優(yōu)勢是它們?yōu)樽x和寫分別提供了鎖,它能滿足你寫像ConcurrentHashMap這樣的高性能數(shù)據(jù)結構和有條件的阻塞。Java線程面試的問題越來越會根據(jù)面試者的回答來提問。我強烈建議在你去參加多線程的面試之前認真讀一下Locks,因為當前其大量用于構建電子交易終統(tǒng)的客戶端緩存和交易連接空間。
3)在java中wait和sleep方法的不同?
通常會在電話面試中經(jīng)常被問到的Java線程面試問題。最大的不同是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait通常被用于線程間交互,sleep通常被用于暫停執(zhí)行。
4)用Java實現(xiàn)阻塞隊列。
這是一個相對艱難的多線程面試問題,它能達到很多的目的。第一,它可以檢測侯選者是否能實際的用Java線程寫程序;第二,可以檢測侯選者對并發(fā)場景的理解,并且你可以根據(jù)這個問很多問題。如果他用wait()和notify()方法來實現(xiàn)阻塞隊列,你可以要求他用最新的Java 5中的并發(fā)類來再寫一次。
5)用Java寫代碼來解決生產(chǎn)者——消費者問題。
與上面的問題很類似,但這個問題更經(jīng)典,有些時候面試都會問下面的問題。在Java中怎么解決生產(chǎn)者——消費者問題,當然有很多解決方法,我已經(jīng)分享了一種用阻塞隊列實現(xiàn)的方法。有些時候他們甚至會問怎么實現(xiàn)哲學家進餐問題。
參見:http://emrowgh.com
6)用Java編程一個會導致死鎖的程序,你將怎么解決?
這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程并發(fā)程序時非常普遍,但是很多侯選者并不能寫deadlock free code(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個資源和N個線程,并且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2,越大的數(shù)據(jù)會使問題看起來更復雜。通過避免Java中的死鎖來得到關于死鎖的更多信息。
死鎖示例:
import java.lang.Class;import http://emrowgh.comnstructor;import http://emrowgh.comncurrent.ArrayBlockingQueue;import http://emrowgh.comncurrent.BlockingQueue;import http://emrowgh.comncurrent.Callable;import http://emrowgh.comncurrent.FutureTask;class A {public synchronized void first(B b){System.out.println("當前線程名:" + Thread.currentThread().getName() + " 進入了A方法");try{Thread.sleep(1000);}catch(Exception e1){e1.printStackTrace();}System.out.println("當前線程名: " + Thread.currentThread().getName()+ " 企圖調(diào)用B實例的last方法");b.last();}public synchronized void last(){System.out.println("當前線程名:" + Thread.currentThread().getName() + "進入了A的last方法");}}class B{public synchronized void first(A a){System.out.println("當前線程名:" + Thread.currentThread().getName() + "進入了B方法");try{Thread.sleep(1000);}catch(Exception e1){e1.printStackTrace();}System.out.println("當前線程名: " + Thread.currentThread().getName()+ " 企圖調(diào)用A類的last方法");a.last();}public synchronized void last(){System.out.println("當前線程名:" + Thread.currentThread().getName() + "進入了B的last方法");}}public class Offer implements Runnable {A a = new A();B b = new B();public void init(){Thread.currentThread().setName("主線程");a.first(b);}public void run(){try{Thread.currentThread().setName("副線程");b.first(a);}catch(Exception e){e.printStackTrace();}}public static void main(String[] args) {Offer offer = new Offer();(new Thread(offer)).start();offer.init();}
【多線程編程面試題】相關文章:
外企面試題05-01
面試題目精選05-01
招聘翻譯的面試題06-09
高職面試題目03-03
面試題回答的技巧05-18
應急面試題目及答案06-06
情景面試題題目及答案03-15
招聘基建主管面試題06-15
營銷招聘面試題及答案06-01
醫(yī)學檢驗面試題目03-26