1)在Java中Lock接口比synchronized塊的優(yōu)勢(shì)是什么策州?你需要實(shí)現(xiàn)一個(gè)高效的緩存,它允許多個(gè)用戶讀宫仗,但只允許一個(gè)用戶寫够挂,以此來保持它的完整性,你會(huì)怎樣去實(shí)現(xiàn)它锰什?
lock接口在多線程和并發(fā)編程中最大的優(yōu)勢(shì)是它們?yōu)樽x和寫分別提供了鎖下硕,它能滿足你寫像ConcurrentHashMap這樣的高性能數(shù)據(jù)結(jié)構(gòu)和有條件的阻塞。Java線程面試的問題越來越會(huì)根據(jù)面試者的回答來提問汁胆。我強(qiáng)烈建議在你去參加多線程的面試之前認(rèn)真讀一下Locks梭姓,因?yàn)楫?dāng)前其大量用于構(gòu)建電子交易終統(tǒng)的客戶端緩存和交易連接空間。
2)在java中wait和sleep方法的不同嫩码?
通常會(huì)在電話面試中經(jīng)常被問到的Java線程面試問題誉尖。最大的不同是在等待時(shí)wait會(huì)釋放鎖,而sleep一直持有鎖铸题。Wait通常被用于線程間交互铡恕,sleep通常被用于暫停執(zhí)行。
3)用Java實(shí)現(xiàn)阻塞隊(duì)列丢间。
這是一個(gè)相對(duì)艱難的多線程面試問題探熔,它能達(dá)到很多的目的。第一烘挫,它可以檢測(cè)侯選者是否能實(shí)際的用Java線程寫程序诀艰;第二,可以檢測(cè)侯選者對(duì)并發(fā)場(chǎng)景的理解饮六,并且你可以根據(jù)這個(gè)問很多問題。如果他用wait()和notify()方法來實(shí)現(xiàn)阻塞隊(duì)列绿满,你可以要求他用最新的Java 5中的并發(fā)類來再寫一次窟扑。
4)用Java寫代碼來解決生產(chǎn)者——消費(fèi)者問題。
與上面的問題很類似橘霎,但這個(gè)問題更經(jīng)典厂抖,有些時(shí)候面試都會(huì)問下面的問題忱辅。在Java中怎么解決生產(chǎn)者——消費(fèi)者問題,當(dāng)然有很多解決方法墙懂,我已經(jīng)分享了一種用阻塞隊(duì)列實(shí)現(xiàn)的方法。有些時(shí)候他們甚至?xí)栐趺磳?shí)現(xiàn)哲學(xué)家進(jìn)餐問題碧库。
5)用Java編程一個(gè)會(huì)導(dǎo)致死鎖的程序巧勤,你將怎么解決?
這是我最喜歡的Java線程面試問題沽瞭,因?yàn)榧词顾梨i問題在寫多線程并發(fā)程序時(shí)非常普遍剩瓶,但是很多侯選者并不能寫deadlock free code(無死鎖代碼?)延曙,他們很掙扎。只要告訴他們布疙,你有N個(gè)資源和N個(gè)線程魂仍,并且你需要所有的資源來完成一個(gè)操作。為了簡單這里的n可以替換為2俱诸,越大的數(shù)據(jù)會(huì)使問題看起來更復(fù)雜赊舶。通過避免Java中的死鎖來得到關(guān)于死鎖的更多信息。
6)什么是原子操作园骆,Java中的原子操作是什么寓调?
非常簡單的java線程面試問題,接下來的問題是你需要同步一個(gè)原子操作晌涕。
7) Java中的Volatile關(guān)鍵是什么作用?怎樣使用它重窟?在Java中它跟synchronized方法有什么不同惧财?
自從Java 5和Java內(nèi)存模型改變以后,基于volatile關(guān)鍵字的線程問題越來越流行厅翔。應(yīng)該準(zhǔn)備好回答關(guān)于volatile變量怎樣在并發(fā)環(huán)境中確绷泵遥可見性、順序性和一致性涩赢。
8) 什么是競爭條件轩勘?你怎樣發(fā)現(xiàn)和解決競爭?
這是一道出現(xiàn)在多線程面試的高級(jí)階段的問題花墩。大多數(shù)的面試官會(huì)問最近你遇到的競爭條件澄步,以及你是怎么解決的。有些時(shí)間他們會(huì)寫簡單的代碼祠肥,然后讓你檢測(cè)出代碼的競爭條件梯皿。可以參考我之前發(fā)布的關(guān)于Java競爭條件的文章东羹。在我看來這是最好的java線程面試問題之一,它可以確切的檢測(cè)候選者解決競爭條件的經(jīng)驗(yàn)权逗,or writing code which is free of data race or any other race condition。關(guān)于這方面最好的書是《Concurrency practices in Java》火惊。
9) 你將如何使用thread dump奔垦?你將如何分析Thread dump椿猎?
在UNIX中你可以使用kill -3寿弱,然后thread dump將會(huì)打印日志,在windows中你可以使用”CTRL+Break”筐咧。非常簡單和專業(yè)的線程面試問題噪矛,但是如果他問你怎樣分析它,就會(huì)很棘手残炮。
10) 為什么我們調(diào)用start()方法時(shí)會(huì)執(zhí)行run()方法缩滨,為什么我們不能直接調(diào)用run()方法?
這是另一個(gè)非常經(jīng)典的java多線程面試問題苞冯。這也是我剛開始寫線程程序時(shí)候的困惑〔嗑蓿現(xiàn)在這個(gè)問題通常在電話面試或者是在初中級(jí)Java面試的第一輪被問到。這個(gè)問題的回答應(yīng)該是這樣的刃泡,當(dāng)你調(diào)用start()方法時(shí)你將創(chuàng)建新的線程烘贴,并且執(zhí)行在run()方法里的代碼。但是如果你直接調(diào)用run()方法桨踪,它不會(huì)創(chuàng)建新的線程也不會(huì)執(zhí)行調(diào)用線程的代碼。閱讀我之前寫的《start與run方法的區(qū)別》這篇文章來獲得更多信息铺峭。
11) Java中你怎樣喚醒一個(gè)阻塞的線程?
這是個(gè)關(guān)于線程和阻塞的棘手的問題傀履,它有很多解決方法莉炉。如果線程遇到了IO阻塞,我并且不認(rèn)為有一種方法可以中止線程梆暮。如果線程因?yàn)檎{(diào)用wait()绍昂、sleep()、或者join()方法而導(dǎo)致的阻塞唠椭,你可以中斷線程忍饰,并且通過拋出InterruptedException來喚醒它。我之前寫的《How to deal with blocking methods in java》有很多關(guān)于處理線程阻塞的信息撩荣。
12)在Java中CycliBarriar和CountdownLatch有什么區(qū)別饶深?
這個(gè)線程問題主要用來檢測(cè)你是否熟悉JDK5中的并發(fā)包。這兩個(gè)的區(qū)別是CyclicBarrier可以重復(fù)使用已經(jīng)通過的障礙台猴,而CountdownLatch不能重復(fù)使用俱两。
13) 什么是不可變對(duì)象,它對(duì)寫并發(fā)應(yīng)用有什么幫助休讳?
另一個(gè)多線程經(jīng)典面試問題尿孔,并不直接跟線程有關(guān)筹麸,但間接幫助很多雏婶。這個(gè)java面試問題可以變的非常棘手,如果他要求你寫一個(gè)不可變對(duì)象酵紫,或者問你為什么String是不可變的。
14) 你在多線程環(huán)境中遇到的共同的問題是什么憨闰?你是怎么解決它的需五?
多線程和并發(fā)程序中常遇到的有Memory-interface宏邮、競爭條件缸血、死鎖、活鎖和饑餓飒炎。問題是沒有止境的笆豁,如果你弄錯(cuò)了,將很難發(fā)現(xiàn)和調(diào)試煞赢。這是大多數(shù)基于面試的哄孤,而不是基于實(shí)際應(yīng)用的Java線程問題。
補(bǔ)充的其它幾個(gè)問題
1) 在java中綠色線程和本地線程區(qū)別凝危?
2) 線程與進(jìn)程的區(qū)別晨逝?
3) 什么是多線程中的上下文切換?
4)死鎖與活鎖的區(qū)別趴生,死鎖與餡餅的區(qū)別?
5) Java中用到的線程調(diào)度算法是什么苍匆?
6) 在Java中什么是線程調(diào)度?
7) 在線程中你怎么處理不可捕捉異常叔汁?
8) 什么是線程組检碗,為什么在Java中不推薦使用?
9) 為什么使用Executor框架比使用應(yīng)用創(chuàng)建和管理線程好另假?
10) 在Java中Executor和Executors的區(qū)別?
11) 如何在Windows和Linux上查找哪個(gè)線程使用的CPU時(shí)間最長边篮?
工作一到五年的java 開發(fā)工程師朋友可以加入我們Java架構(gòu)交流群:760940986
群內(nèi)提供 高可用,高并發(fā)戈轿,spring源碼阵子,mybatis源碼,JVM色乾,大數(shù)據(jù)领突,Netty等多個(gè)技術(shù)知識(shí)的架構(gòu)視頻資料
還有大把大牛在群內(nèi)交流以及解答面試指導(dǎo),問題答疑~~要進(jìn)來和大牛交流學(xué)習(xí)提升提升自己嗎~~~~