1)現(xiàn)在有T1、T2擎鸠、T3三個線程揭鳞,你怎樣保證T2在T1執(zhí)行完后執(zhí)行炕贵,T3在T2執(zhí)行完后執(zhí)行?
這個線程問題通常會在第一輪或電話面試階段被問到野崇,目的是檢測你對”join”方法是否熟悉称开。這個多線程問題比較簡單,可以用join方法實現(xiàn)乓梨。
---------------------------------------------------------------------------------------------------------------------------------------
此外我整理了很多PDF版的資料(不僅限于下圖中的)鳖轰,需要的自取 (文章底部獲取)扶镀!
獲取鏈接:JAVA 面試題 PDF版下載
---------------------------------------------------------------------------------------------------------------------------------------
2)在Java中Lock接口比synchronized塊的優(yōu)勢是什么蕴侣?你需要實現(xiàn)一個高效的緩存,它允許多個用戶讀臭觉,但只允許一個用戶寫昆雀,以此來保持它的完整性辱志,你會怎樣去實現(xiàn)它?
lock接口在多線程和并發(fā)編程中最大的優(yōu)勢是它們?yōu)樽x和寫分別提供了鎖狞膘,它能滿足你寫像ConcurrentHashMap這樣的高性能數(shù)據(jù)結(jié)構(gòu)和有條件的阻塞荸频。Java線程面試的問題越來越會根據(jù)面試者的回答來提問。我強烈建議在你去參加多線程的面試之前認真讀一下Locks客冈,因為當前其大量用于構(gòu)建電子交易終統(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)哲學家進餐問題。
6)用Java編程一個會導致死鎖的程序厦酬,你將怎么解決尉共?
這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程并發(fā)程序時非常普遍弃锐,但是很多侯選者并不能寫deadlock free code(無死鎖代碼袄友?),他們很掙扎霹菊。只要告訴他們剧蚣,你有N個資源和N個線程支竹,并且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2鸠按,越大的數(shù)據(jù)會使問題看起來更復雜礼搁。通過避免Java中的死鎖來得到關于死鎖的更多信息。
7) 什么是原子操作目尖,Java中的原子操作是什么馒吴?
非常簡單的java線程面試問題,接下來的問題是你需要同步一個原子操作瑟曲。
8) Java中的volatile關鍵是什么作用饮戳?怎樣使用它?在Java中它跟synchronized方法有什么不同洞拨?
自從Java 5和Java內(nèi)存模型改變以后扯罐,基于volatile關鍵字的線程問題越來越流行。應該準備好回答關于volatile變量怎樣在并發(fā)環(huán)境中確狈骋拢可見性歹河。
9) 什么是競爭條件?你怎樣發(fā)現(xiàn)和解決競爭花吟?
這是一道出現(xiàn)在多線程面試的高級階段的問題秸歧。大多數(shù)的面試官會問最近你遇到的競爭條件,以及你是怎么解決的衅澈。有些時間他們會寫簡單的代碼寥茫,然后讓你檢測出代碼的競爭條件》椋可以參考我之前發(fā)布的關于Java競爭條件的文章纱耻。在我看來這是最好的java線程面試問題之一,它可以確切的檢測候選者解決競爭條件的經(jīng)驗险耀,or writing code which is free of data race or anyother race condition弄喘。關于這方面最好的書是《Concurrency practices in Java》。
10) 你將如何使用threaddump甩牺?你將如何分析Thread dump蘑志?
在UNIX中你可以使用kill -3,然后thread dump將會打印日志贬派,在windows中你可以使用”CTRL+Break”急但。非常簡單和專業(yè)的線程面試問題,但是如果他問你怎樣分析它搞乏,就會很棘手波桩。
11) 為什么我們調(diào)用start()方法時會執(zhí)行run()方法,為什么我們不能直接調(diào)用run()方法请敦?
這是另一個非常經(jīng)典的java多線程面試問題镐躲。這也是我剛開始寫線程程序時候的困惑〈⒚担現(xiàn)在這個問題通常在電話面試或者是在初中級Java面試的第一輪被問到。這個問題的回答應該是這樣的萤皂,當你調(diào)用start()方法時你將創(chuàng)建新的線程撒穷,并且執(zhí)行在run()方法里的代碼。但是如果你直接調(diào)用run()方法裆熙,它不會創(chuàng)建新的線程也不會執(zhí)行調(diào)用線程的代碼端礼。閱讀我之前寫的《start與run方法的區(qū)別》這篇文章來獲得更多信息。
12) Java中你怎樣喚醒一個阻塞的線程入录?
這是個關于線程和阻塞的棘手的問題蛤奥,它有很多解決方法。如果線程遇到了IO阻塞纷跛,我并且不認為有一種方法可以中止線程。如果線程因為調(diào)用wait()邀杏、sleep()贫奠、或者join()方法而導致的阻塞,你可以中斷線程望蜡,并且通過拋出InterruptedException來喚醒它唤崭。我之前寫的《How to deal with blocking methods in java》有很多關于處理線程阻塞的信息。
13)在Java中CycliBarriar和CountdownLatch有什么區(qū)別脖律?
這個線程問題主要用來檢測你是否熟悉JDK5中的并發(fā)包谢肾。這兩個的區(qū)別是CyclicBarrier可以重復使用已經(jīng)通過的障礙,而CountdownLatch不能重復使用小泉。
14) 什么是不可變對象芦疏,它對寫并發(fā)應用有什么幫助?
另一個多線程經(jīng)典面試問題微姊,并不直接跟線程有關酸茴,但間接幫助很多。這個java面試問題可以變的非常棘手兢交,如果他要求你寫一個不可變對象薪捍,或者問你為什么String是不可變的。
15) 你在多線程環(huán)境中遇到的常見的問題是什么配喳?你是怎么解決它的酪穿?
多線程和并發(fā)程序中常遇到的有Memory-interface、競爭條件晴裹、死鎖被济、活鎖和饑餓。問題是沒有止境的涧团,如果你弄錯了溉潭,將很難發(fā)現(xiàn)和調(diào)試净响。這是大多數(shù)基于面試的,而不是基于實際應用的Java線程問題喳瓣。
獲取鏈接:
知乎 - 安全中心?windyman.top