大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 常見問題 Java多線程面試題及回答(詳細總結)

Java多線程面試題及回答(詳細總結)

更新時間:2019-06-12 10:35:15 來源:動力節(jié)點 瀏覽5883次

在任何Java面試當中多線程和并發(fā)方面的問題都是必不可少的一部分。如果你想獲得任何股票投資銀行的前臺資訊職位,那么你應該準備很多關于多線程的問題。在投資銀行業(yè)務中多線程和并發(fā)是一個非常受歡迎的話題,特別是電子交易發(fā)展方面相關的,他們會問面試者很多令人混淆的Java線程問題,面試官只是想確信面試者有足夠的Java線程與并發(fā)方面的知識,因為候選人中有很多只浮于表面,用于直接面向市場交易的高容量和低延時的電子交易系統(tǒng)在本質上是并發(fā)的。下面這些是我在不同時間不同地點喜歡問的Java線程問題,我沒有提供答案,但只要可能我會給你線索,有些時候這些線索足夠回答問題,現(xiàn)在引用Java5并發(fā)包關于并發(fā)工具和并發(fā)集合的問題正在增多。那些問題中ThreadLocal、BlockingQueue、CountingSemaphore和ConcurrentHashMap比較流行。

Java多線程面試題及回答(詳細總結).jpg

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方法的不同?

通常會在電話面試中經常被問到的Java線程面試問題。最大的不同是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait通常被用于線程間交互,sleep通常被用于暫停執(zhí)行。

4.用Java實現(xiàn)阻塞隊列。

這是一個相對艱難的多線程面試問題,它能達到很多的目的。第一,它可以檢測侯選者是否能實際的用Java線程寫程序;第二,可以檢測侯選者對并發(fā)場景的理解,并且你可以根據(jù)這個問很多問題。如果他用wait()和notify()方法來實現(xiàn)阻塞隊列,你可以要求他用最新的Java5中的并發(fā)類來再寫一次。

5.用Java寫代碼來解決生產者——消費者問題。

與上面的問題很類似,但這個問題更經典,有些時候面試都會問下面的問題。在Java中怎么解決生產者——消費者問題,當然有很多解決方法,我已經分享了一種用阻塞隊列實現(xiàn)的方法。有些時候他們甚至會問怎么實現(xiàn)哲學家進餐問題。

6.用Java編程一個會導致死鎖的程序,你將怎么解決?

這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程并發(fā)程序時非常普遍,但是很多侯選者并不能寫deadlockfreecode(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個資源和N個線程,并且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2,越大的數(shù)據(jù)會使問題看起來更復雜。通過避免Java中的死鎖來得到關于死鎖的更多信息。

7.什么是原子操作,Java中的原子操作是什么?

非常簡單的java線程面試問題,接下來的問題是你需要同步一個原子操作。

8.Java中的volatile關鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?

自從Java5和Java內存模型改變以后,基于volatile關鍵字的線程問題越來越流行。應該準備好回答關于volatile變量怎樣在并發(fā)環(huán)境中確保可見性、順序性和一致性。

9.什么是競爭條件?你怎樣發(fā)現(xiàn)和解決競爭?

這是一道出現(xiàn)在多線程面試的高級階段的問題。大多數(shù)的面試官會問最近你遇到的競爭條件,以及你是怎么解決的。有些時間他們會寫簡單的代碼,然后讓你檢測出代碼的競爭條件。可以參考我之前發(fā)布的關于Java競爭條件的文章。在我看來這是最好的java線程面試問題之一,它可以確切的檢測候選者解決競爭條件的經驗,orwritingcodewhichisfreeofdataraceoranyotherracecondition。關于這方面最好的書是《ConcurrencypracticesinJava》。

10.你將如何使用threaddump?你將如何分析Threaddump?

在UNIX中你可以使用kill-3,然后threaddump將會打印日志,在windows中你可以使用”CTRL+Break”。非常簡單和專業(yè)的線程面試問題,但是如果他問你怎樣分析它,就會很棘手。

11.為什么我們調用start()方法時會執(zhí)行run()方法,為什么我們不能直接調用run()方法?

這是另一個非常經典的java多線程面試問題。這也是我剛開始寫線程程序時候的困惑。現(xiàn)在這個問題通常在電話面試或者是在初中級Java面試的第一輪被問到。這個問題的回答應該是這樣的,當你調用start()方法時你將創(chuàng)建新的線程,并且執(zhí)行在run()方法里的代碼。但是如果你直接調用run()方法,它不會創(chuàng)建新的線程也不會執(zhí)行調用線程的代碼。閱讀我之前寫的《start與run方法的區(qū)別》這篇文章來獲得更多信息。

12.Java中你怎樣喚醒一個阻塞的線程?

這是個關于線程和阻塞的棘手的問題,它有很多解決方法。如果線程遇到了IO阻塞,我并且不認為有一種方法可以中止線程。如果線程因為調用wait()、sleep()、或者join()方法而導致的阻塞,你可以中斷線程,并且通過拋出InterruptedException來喚醒它。我之前寫的《Howtodealwithblockingmethodsinjava》有很多關于處理線程阻塞的信息。

13.在Java中CycliBarriar和CountdownLatch有什么區(qū)別?

這個線程問題主要用來檢測你是否熟悉JDK5中的并發(fā)包。這兩個的區(qū)別是CyclicBarrier可以重復使用已經通過的障礙,而CountdownLatch不能重復使用。

14.什么是不可變對象,它對寫并發(fā)應用有什么幫助?

另一個多線程經典面試問題,并不直接跟線程有關,但間接幫助很多。這個java面試問題可以變的非常棘手,如果他要求你寫一個不可變對象,或者問你為什么String是不可變的。

15.你在多線程環(huán)境中遇到的共同的問題是什么?你是怎么解決它的?

多線程和并發(fā)程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和饑餓。問題是沒有止境的,如果你弄錯了,將很難發(fā)現(xiàn)和調試。這是大多數(shù)基于面試的,而不是基于實際應用的Java線程問題。

以上就是動力節(jié)點Java培訓機構小編介紹的“Java多線程面試題及回答”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為您服務。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久久久精品日本一区二区三区 | 亚洲高清专区 | 精品国产成人三级在线观看 | 成年午夜视频免费观看视频 | 欧美一级大片在线观看 | 日本老年人精品久久中文字幕 | 日本伊人精品一区二区三区 | 一级毛片免费播放 | 夜夜操网 | 另类综合图片 | 婷婷成人综合 | 99热这里只有精品首页精品 | 手机免费在线观看 | 日韩欧美一中字暮 | 亚洲成人高清在线 | 免费观看成人羞羞视频网站观看 | 久久水蜜桃 | 亚洲欧美一区二区三区在线播放 | 亚洲视频福利 | 国产福利视频 | 一区二区精品在线观看 | 99久久免费国内精品 | 亚洲小视频在线观看 | 亚洲视频免费在线观看 | 在线成人精品国产区免费 | 日韩在线欧美在线 | 在线观看免费毛片 | 欧美日韩一区二区三区自拍 | 亚洲欧美香蕉在线日韩精选 | 亚洲a网 | 国产成人亚综合91精品首页 | 奇米777第四 | 欧美理论片大全在线观看 | 久久精品国产99精品最新 | 欧美成人免费高清网站 | 国产欧美久久久精品影院 | 色视频网站人成免费 | 国产精品一区二区久久精品涩爱 | 亚洲欧美国产精品专区久久 | 国产亚洲欧美日韩国产片 | 性欧美高清久久久久久久 |