不卡AV在线|网页在线观看无码高清|亚洲国产亚洲国产|国产伦精品一区二区三区免费视频

學(xué)習(xí)啦 > 創(chuàng)業(yè)指南 > 職場 > 面試題 > 高級Java多線程面試題及回答

高級Java多線程面試題及回答

時(shí)間: 澤凡0 分享

職場高級Java多線程面試題及回答

在IT職場,任何時(shí)候面試java工程師,當(dāng)中多線程和并發(fā)方面的問題都是必不可少的一部分。本文是小編搜索整理的關(guān)于高級Java多線程面試題及回答,供參考學(xué)習(xí),希望對大家有所幫助!

高級Java多線程面試題及回答

高級Java多線程面試題及回答

1)現(xiàn)在有T1、T2、T3三個(gè)線程,你怎樣保證T2在T1執(zhí)行完后執(zhí)行,T3在T2執(zhí)行完后執(zhí)行?

這個(gè)線程問題通常會在第一輪或電話面試階段被問到,目的是檢測你對”join”方法是否熟悉。這個(gè)多線程問題比較簡單,可以用join方法實(shí)現(xiàn)。

2)在Java中Lock接口比synchronized塊的優(yōu)勢是什么?你需要實(shí)現(xiàn)一個(gè)高效的緩存,它允許多個(gè)用戶讀,但只允許一個(gè)用戶寫,以此來保持它的完整性,你會怎樣去實(shí)現(xiàn)它?

lock接口在多線程和并發(fā)編程中最大的優(yōu)勢是它們?yōu)樽x和寫分別提供了鎖,它能滿足你寫像ConcurrentHashMap這樣的高性能數(shù)據(jù)結(jié)構(gòu)和有條件的阻塞。Java線程面試的問題越來越會根據(jù)面試者的回答來提問。我強(qiáng)烈建議在你去參加多線程的面試之前認(rèn)真讀一下Locks,因?yàn)楫?dāng)前其大量用于構(gòu)建電子交易終統(tǒng)的客戶端緩存和交易連接空間。

3)在java中wait和sleep方法的不同?

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

4)用Java實(shí)現(xiàn)阻塞隊(duì)列。

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

5)用Java寫代碼來解決生產(chǎn)者——消費(fèi)者問題。

與上面的問題很類似,但這個(gè)問題更經(jīng)典,有些時(shí)候面試都會問下面的問題。在Java中怎么解決生產(chǎn)者——消費(fèi)者問題,當(dāng)然有很多解決方法,我已經(jīng)分享了一種用阻塞隊(duì)列實(shí)現(xiàn)的方法。有些時(shí)候他們甚至?xí)栐趺磳?shí)現(xiàn)哲學(xué)家進(jìn)餐問題。

6)用Java編程一個(gè)會導(dǎo)致死鎖的程序,你將怎么解決?

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

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

非常簡單的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)境中確??梢娦?、順序性和一致性。

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

這是一道出現(xiàn)在多線程面試的高級階段的問題。大多數(shù)的面試官會問最近你遇到的競爭條件,以及你是怎么解決的。有些時(shí)間他們會寫簡單的代碼,然后讓你檢測出代碼的競爭條件。可以參考我之前發(fā)布的關(guān)于Java競爭條件的文章。在我看來這是最好的java線程面試問題之一,它可以確切的檢測候選者解決競爭條件的經(jīng)驗(yàn),or writing code which is free of data race or any other race condition(這句which is free of data race不會翻譯)。關(guān)于這方面最好的書是《Concurrency practices in Java》。

10) 你將如何使用thread dump?你將如何分析Thread dump?

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

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

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

12) 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)于處理線程阻塞的信息。

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

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

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

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

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

多線程和并發(fā)程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和饑餓。問題是沒有止境的,如果你弄錯了,將很難發(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編程語言擴(kuò)展閱讀

Java編程語言

我對進(jìn)程、線程的了解,主要是學(xué)生時(shí)代看過的`一本大概叫做“C++面象對象多線程編程”的書,是美國人寫的。后來學(xué)Java編程語言,一直是馬馬虎虎,以完成任務(wù)為目標(biāo),沒有像學(xué)C++那樣打?qū)嵒A(chǔ)(C++的基礎(chǔ)也忘差不多了,汗)。這不做東西時(shí)又碰到麻煩,經(jīng)過排查解決,有幾個(gè)簡單知識點(diǎn)做一下筆記。

第一個(gè)是run()與start()。

翻翻以前自己寫的代碼,是用start()啟動線程的,這次居然犯糊涂用run()來跑,不出錯才怪呢。相信有不少Java編程語言程序員像我一樣,在不懂的時(shí)候,就按個(gè)點(diǎn),查看方法列表,跟據(jù)方法名想當(dāng)然地理解。這種方法可以快速入手做東西,但像多線程這類的東西,還是需要打牢基礎(chǔ),不然麻煩多多。

run()只是一個(gè)普通方法,是Runnable接口定義的,用來執(zhí)行線程最終要做的事情的方法,它本身沒有特別之處,就像main方法一樣,啟動一個(gè)線程后,run()方法會被調(diào)用。所以,run()方法沒有創(chuàng)建多線程,run()方法里的東西還在調(diào)用者線程里跑。

start()方法是Thread類定義的,它是真正負(fù)責(zé)啟動一個(gè)線程的。調(diào)用此方法后,將會從線程創(chuàng)建一個(gè)新的線程出來(強(qiáng)調(diào)從當(dāng)前線程創(chuàng)建新線程是因?yàn)橐恍傩员热鏳aemon會被繼承),然后在新線程執(zhí)行run()方法。

第二個(gè)就是InterruptedException。

典型地,我們在run()方法中常用while循環(huán),并且每次循環(huán)通常有Thread.sleep(long)調(diào)用,這個(gè)sleep(long)方法會拋出InterruptedException。之前對這個(gè)異常的理解有誤,以為這是個(gè)“錯誤”,其實(shí)這只是表示一個(gè)狀態(tài)??垂俜轿臋n有點(diǎn)拗口,簡單地說,這個(gè)異常被拋出表示線程收到中斷請求(你也可以理解為線程正在被終止,通常是這樣,但不絕對。

為了線程安全、保證數(shù)據(jù)的一致性,Java編程語言提倡用溫和手?jǐn)嘀兄咕€程,溫和的意思就是run()方法里的代碼有機(jī)會決定什么時(shí)候退出),比如外部調(diào)用interrupt()來中斷此線程。sleep()收到中斷異常意味著sleep時(shí)外部發(fā)來了中斷請求信號,這時(shí)如果沒有需要善后的操作,就可以退出while循環(huán),結(jié)束線程了。

我以前的代碼是catch掉打一句日志,雖然正常工作了,但是卻是錯誤的。

第三個(gè)是Thread.interrupted()和thread.isInterrupted()的區(qū)別(后者thread代表Thread的一個(gè)實(shí)例)。

兩者都返回線程的當(dāng)前狀態(tài),區(qū)別在于前者返回當(dāng)前狀態(tài)后,會復(fù)會這個(gè)狀態(tài)。比如Thread.interrupted()得了true,但此后線程狀態(tài)被立即置為了false。如果不想改變這一狀態(tài),可以用isInterrupted(),比如Thread.currentThread.isInterrupted()。

還有就是中斷狀態(tài)是會被一些操作改變的,所以不能只用此狀態(tài)來斷段線程是否要退出。線程應(yīng)該另外設(shè)置一個(gè)退出標(biāo)記(如果需要控制線程的運(yùn)行與否的話)。

Java高級開發(fā)工程師崗位的工作職責(zé)說明

職責(zé):

1.負(fù)責(zé)公司產(chǎn)品研發(fā),代碼編寫及評審。

2.負(fù)責(zé)系統(tǒng)框架的搭建及系統(tǒng)調(diào)優(yōu)。

3.負(fù)責(zé)需求調(diào)研、可行性分析和需求分析,撰寫相關(guān)的技術(shù)文檔。

4.產(chǎn)品上線后,配合運(yùn)維團(tuán)隊(duì)保障平臺的穩(wěn)定,解決相關(guān)技術(shù)問題。

5.協(xié)助并完成其他各類技術(shù)開發(fā)任務(wù)。

6.帶領(lǐng)團(tuán)隊(duì)解決問題,并對初中級開發(fā)進(jìn)行指導(dǎo)。

任職要求:

1.本科及以上學(xué)歷,計(jì)算機(jī)相關(guān)專業(yè),5年以上相關(guān)工作經(jīng)驗(yàn)。

2.熟悉主流的Java開發(fā)框架如Spring, SpringMVC, Mybatis,SpringBoot,SpringCloud等。

3.了解 Kafka Redis等。

4.掌握數(shù)據(jù)庫相關(guān)知識,熟悉Oracle數(shù)據(jù)庫,能熟練運(yùn)用SQL語言,具備一定的SQL調(diào)優(yōu)經(jīng)驗(yàn)。

5.熟悉Linux系統(tǒng),熟悉SVN、GIT等代碼版本管理工具,熟悉Maven等項(xiàng)目工具。

6.熟練使用redis 緩存,熟悉搜索引擎Solr或elasticsearch。

7.具有技術(shù)文檔編寫的能力。

8.熟悉Linux、Tomcat,Apache,Nginx等開源的服務(wù)器和Web服務(wù)中間件。

9.基本功扎實(shí),邏輯思維嚴(yán)謹(jǐn),善于獨(dú)立思考,樂于分享,良好的協(xié)作意識及團(tuán)隊(duì)精神。

1831186