高級(jí)java面試題及答案
Java高級(jí)工程師在面試中,對(duì)面是問題提前了解很重要,你知道哪些高級(jí)Java面試題呢?以下是小編幫你們整理的高級(jí)java面試題及答案,一起來學(xué)習(xí)啦。
高級(jí)java面試題及答案(一)
1、現(xiàn)在有T1、T2、T3三個(gè)線程,你怎樣保證T2在T1執(zhí)行完后執(zhí)行,T3在T2執(zhí)行完后執(zhí)行?
這個(gè)線程問題通常會(huì)在第一輪或電話面試階段被問到,目的是檢測(cè)你對(duì)”join”方法是否熟悉。這個(gè)多線程問題比較簡(jiǎn)單,可以用join方法實(shí)現(xiàn)。
2、在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)的客戶端緩存和交易連接空間。
3、在java中wait和sleep方法的不同?
通常會(huì)在電話面試中經(jīng)常被問到的Java線程面試問題。最大的不同是在等待時(shí)wait會(huì)釋放鎖,而sleep一直持有鎖。Wait通常被用于線程間交互,sleep通常被用于暫停執(zhí)行。
4、用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ā)類來再寫一次。
5、用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)餐問題。
6、用Java編程一個(gè)會(huì)導(dǎo)致死鎖的程序,你將怎么解決?
這是我最喜歡的Java線程面試問題,因?yàn)榧词顾梨i問題在寫多線程并發(fā)程序時(shí)非常普遍,但是很多侯選者并不能寫deadlock free code(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個(gè)資源和N個(gè)線程,并且你需要所有的資源來完成一個(gè)操作。為了簡(jiǎn)單這里的n可以替換為2,越大的數(shù)據(jù)會(huì)使問題看起來更復(fù)雜。通過避免Java中的死鎖來得到關(guān)于死鎖的更多信息。
7、什么是原子操作,Java中的原子操作是什么?
非常簡(jiǎn)單的java線程面試問題,接下來的問題是你需要同步一個(gè)原子操作。
8、Java中的volatile關(guān)鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?
自從Java 5和Java內(nèi)存模型改變以后,基于volatile關(guān)鍵字的線程問題越來越流行。應(yīng)該準(zhǔn)備好回答關(guān)于volatile變量怎樣在并發(fā)環(huán)境中確??梢娦?、順序性和一致性。
高級(jí)java面試題及答案(二)
1、什么是競(jìng)爭(zhēng)條件?你怎樣發(fā)現(xiàn)和解決競(jìng)爭(zhēng)?
這是一道出現(xiàn)在多線程面試的高級(jí)階段的問題。大多數(shù)的面試官會(huì)問最近你遇到的競(jìng)爭(zhēng)條件,以及你是怎么解決的。有些時(shí)間他們會(huì)寫簡(jiǎn)單的代碼,然后讓你檢測(cè)出代碼的競(jìng)爭(zhēng)條件??梢詤⒖嘉抑鞍l(fā)布的關(guān)于Java競(jìng)爭(zhēng)條件的文章。在我看來這是最好的java線程面試問題之一,它可以確切的檢測(cè)候選者解決競(jìng)爭(zhēng)條件的經(jīng)驗(yàn),or writing code which is free of data race or any other race condition。關(guān)于這方面最好的書是《Concurrency practices in Java》。
2、你將如何使用thread dump?你將如何分析Thread dump?
在UNIX中你可以使用kill -3,然后thread dump將會(huì)打印日志,在windows中你可以使用”CTRL+Break”。非常簡(jiǎn)單和專業(yè)的線程面試問題,但是如果他問你怎樣分析它,就會(huì)很棘手。
3、為什么我們調(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ū)別》這篇文章來獲得更多信息。
4、 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)于處理線程阻塞的信息。
5、在Java中CycliBarriar和CountdownLatch有什么區(qū)別?
這個(gè)線程問題主要用來檢測(cè)你是否熟悉JDK5中的并發(fā)包。這兩個(gè)的區(qū)別是CyclicBarrier可以重復(fù)使用已經(jīng)通過的障礙,而CountdownLatch不能重復(fù)使用。
6、 什么是不可變對(duì)象,它對(duì)寫并發(fā)應(yīng)用有什么幫助?
另一個(gè)多線程經(jīng)典面試問題,并不直接跟線程有關(guān),但間接幫助很多。這個(gè)java面試問題可以變的非常棘手,如果他要求你寫一個(gè)不可變對(duì)象,或者問你為什么String是不可變的。
7、你在多線程環(huán)境中遇到的共同的問題是什么?你是怎么解決它的?
多線程和并發(fā)程序中常遇到的有Memory-interface、競(jìng)爭(zhēng)條件、死鎖、活鎖和饑餓。問題是沒有止境的,如果你弄錯(cuò)了,將很難發(fā)現(xiàn)和調(diào)試。這是大多數(shù)基于面試的,而不是基于實(shí)際應(yīng)用的Java線程問題。
高級(jí)java面試題及答案(三)
1、HashMap和Hashtable的區(qū)別。
HashMap是Hashtable的輕量級(jí)實(shí)現(xiàn)(非線程安全的實(shí)現(xiàn)),他們都完成了Map接口,主要區(qū)別在于HashMap允許空(null)鍵值(key),由于非線程安全,效率上可能高于Hashtable。
HashMap允許將null作為一個(gè)entry的key或者value,而Hashtable不允許。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因?yàn)閏ontains方法容易讓人引起誤解。
Hashtable繼承自Dictionary類,而HashMap是Java1.2引進(jìn)的Map interface的一個(gè)實(shí)現(xiàn)。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個(gè)線程訪問Hashtable時(shí),不需要自己為它的方法實(shí)現(xiàn)同步,而HashMap 就必須為之提供外同步。
Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會(huì)有很大的差異。
2、final, finally, finalize的區(qū)別。
final 用于聲明屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。
finally是異常處理語句結(jié)構(gòu)的一部分,表示總是執(zhí)行。
finalize是Object類的一個(gè)方法,在垃圾收集器執(zhí)行的時(shí)候會(huì)調(diào)用被回收對(duì)象的此方法,可以覆蓋此方法提供垃圾收集時(shí)的其他資源回收,例如關(guān)閉文件等。
3、sleep() 和 wait() 有什么區(qū)別?
sleep是線程類(Thread)的方法,導(dǎo)致此線程暫停執(zhí)行指定時(shí)間,給執(zhí)行機(jī)會(huì)給其他線程,但是監(jiān)控狀態(tài)依然保持,到時(shí)后會(huì)自動(dòng)恢復(fù)。調(diào)用sleep不會(huì)釋放對(duì)象鎖。
wait是Object類的方法,對(duì)此對(duì)象調(diào)用wait方法導(dǎo)致本線程放棄對(duì)象鎖,進(jìn)入等待此對(duì)象的等待鎖定池,只有針對(duì)此對(duì)象發(fā)出notify方法(或notifyAll)后本線程才進(jìn)入對(duì)象鎖定池準(zhǔn)備獲得對(duì)象鎖進(jìn)入運(yùn)行狀態(tài)。
4、Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型?
方法的重寫Overriding和重載Overloading是Java多態(tài)性的不同表現(xiàn)。重寫Overriding是父類與子類之間多態(tài)性的一種表現(xiàn),重載Overloading是一個(gè)類中多態(tài)性的一種表現(xiàn)。如果在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說該方法被重寫 (Overriding)。子類的對(duì)象使用這個(gè)方法時(shí),將調(diào)用子類中的定義,對(duì)它而言,父類中的定義如同被"屏蔽"了。如果在一個(gè)類中定義了多個(gè)同名的方法,它們或有不同的參數(shù)個(gè)數(shù)或有不同的參數(shù)類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。
5、error和exception有什么區(qū)別?
error 表示恢復(fù)不是不可能但很困難的情況下的一種嚴(yán)重問題。比如說內(nèi)存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設(shè)計(jì)或?qū)崿F(xiàn)問題。也就是說,它表示如果程序運(yùn)行正常,從不會(huì)發(fā)生的情況。
看了“高級(jí)java面試題及答案”