阿里常用Java并發(fā)編程面試試題總結

一、概念
什么是線程
- 一個線程要執(zhí)行任務,必須得有線程一個進程(程序)的所有任務都在線程中執(zhí)行的一個線程執(zhí)行任務是串行的,也就是說一個線程,同一時間內(nèi),只能執(zhí)行一個任務
多線程原理
- 同一時間,CPU只能處理1條線程,只有一條線程在工作(執(zhí)行)多線程并發(fā)(同時)執(zhí)行,其實質(zhì)是CPU快速的在多線程之間調(diào)度(切換)
如果線程過多,會怎樣?
- CPU在N多條線程中調(diào)度,會消耗大量的cpu資源每條線程被調(diào)度執(zhí)行的頻率越低(線程的執(zhí)行效率低)
多線程的優(yōu)點
- 能適當提高程序的執(zhí)行效率能適當提高資源的利用率(CPU 內(nèi)存利用率等)
多線程的缺點
- 創(chuàng)建線程是有開銷的,iOS下主要成本包括:內(nèi)核數(shù)據(jù)結構(大約1KB)、??臻g(子線程512KB、主線程1MB,也可以使用-setStackSize:設置,但必須是4K的倍數(shù),而且最小是16K),創(chuàng)建線程大約需要90毫秒的創(chuàng)建時間如果開啟大量的線程,會降低程序的性能程序越多CPU的線程上的開銷就越大程序設計更加復雜:線程之間的通訊,多線程的數(shù)據(jù)共享
主線程的主要作用
- 顯示和刷新UI界面處理UI事件(比如點擊事件,滾動事件,拖拽事件等)
主線程的使用注意
- 別將比較耗時的操作放在主線程中,會導致UI界面的卡頓將耗時操作放在子線程(后臺線程,非主線程)
二、多線程的4種方案
三、常見多線程面試題:
下面這些是我在不同時間不同地點喜歡問的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方法的不同?
通常會在電話面試中經(jīng)常被問到的Java線程面試問題。最大的不同是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait通常被用于線程間交互,sleep通常被用于暫停執(zhí)行。
4.用Java寫代碼來解決生產(chǎn)者——消費者問題。
與上面的問題很類似,但這個問題更經(jīng)典,有些時候面試都會問下面的問題。在Java中怎么解決生產(chǎn)者——消費者問題,當然有很多解決方法,我已經(jīng)分享了一種用阻塞隊列實現(xiàn)的方法。有些時候他們甚至會問怎么實現(xiàn)哲學家進餐問題。
5.你將如何使用thread dump?你將如何分析Thread dump?
在UNIX中你可以使用kill -3,然后thread dump將會打印日志,在windows中你可以使用”CTRL+Break”。非常簡單和專業(yè)的線程面試問題,但是如果他問你怎樣分析它,就會很棘手。
6.****用Java編程一個會導致死鎖的程序,你將怎么解決?
這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程并發(fā)程序時非常普遍,但是很多侯選者并不能寫deadlock free code(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個資源和N個線程,并且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2,越大的數(shù)據(jù)會使問題看起來更復雜。通過避免Java中的死鎖來得到關于死鎖的更多信息。
7.你在多線程環(huán)境中遇到的共同的問題是什么?你是怎么解決它的?
多線程和并發(fā)程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和饑餓。問題是沒有止境的,如果你弄錯了,將很難發(fā)現(xiàn)和調(diào)試。這是大多數(shù)基于面試的,而不是基于實際應用的Java線程問題。
8.為什么我們調(diào)用start()方法時會執(zhí)行run()方法,為什么我們不能直接調(diào)用run()方法?
這是一個非常經(jīng)典的java多線程面試問題。這也是我剛開始寫線程程序時候的困惑?,F(xiàn)在這個問題通常在電話面試或者是在初中級Java面試的第一輪被問到。這個問題的回答應該是這樣的,當你調(diào)用start()方法時你將創(chuàng)建新的線程,并且執(zhí)行在run()方法里的代碼。但是如果你直接調(diào)用run()方法,它不會創(chuàng)建新的線程也不會執(zhí)行調(diào)用線程的代碼。
9.Java中的volatile關鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?
自從Java 5和Java內(nèi)存模型改變以后,基于volatile關鍵字的線程問題越來越流行。應該準備好回答關于volatile變量怎樣在并發(fā)環(huán)境中確??梢娦浴㈨樞蛐院鸵恢滦?。
10.****什么是不可變對象,它對寫并發(fā)應用有什么幫助?
另一個多線程經(jīng)典面試問題,并不直接跟線程有關,但間接幫助很多。這個java面試問題可以變的非常棘手,如果他要求你寫一個不可變對象,或者問你為什么String是不可變的。
四、多線程并發(fā)的學習思路:
五、總結
其實,很多面試官都清楚,初級程序員對于多線程的掌握度幾乎為零。但是面試環(huán)節(jié)中,很多面試官都會抱著試一試的態(tài)度去提問一兩道多線程的題目。其目的不是為了難為面試者,也不是為了彰顯面試的“高大上”,而是為了區(qū)分一般人才與優(yōu)質(zhì)人才。最后一點大家謹記:
在找工作的時候,除了做些相關面試和準備熟悉以前做的項目之外,還應該學習新的知識。畢竟,每多學一點,成功找到工作的機會就大一點。而且,IT這行,技術發(fā)展過于快速,如果沒有學習新知識的動力,終究會被淘汰。
相關文章
2019年成功入職阿里:阿里的三套Java研發(fā)崗面試題總結
之前過了幾個簡單的簡歷面,所以總結了幾套面試的試題供大家分享。小編覺得挺不錯的,也給大家做個參考。一起跟隨小編過來看看吧2019-04-25阿里余額寶團隊Java4面:G1+二叉樹+線上調(diào)優(yōu)+MQ+Redis
這篇文章主要介紹了阿里余額寶團隊Java4面:G1+二叉樹+線上調(diào)優(yōu)+MQ+Redis的相關資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-12精選11道Java技術面試題及對應答案【包含部分阿里和華為的面試題】
這篇文章主要為大家介紹了11道Java技術面試題及對應答案,其中包含部分阿里和華為的面試題,總結分析了java常見的技術難點與java常見面試題,需要的朋友可以參考下2019-04-11- 這篇文章主要介紹了兩道阿里python面試題與參考答案,結合具體實例形式分析了Python數(shù)組創(chuàng)建、遍歷、拆分及隨機數(shù)等相關操作技巧,需要的朋友可以參考下2019-09-02
- 這篇文章主要介紹了阿里、網(wǎng)易、滴滴共十次前端面試碰到的問題小結,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-07-25
兩個月面試經(jīng)歷回顧:阿里,攜程,小紅書,美團,網(wǎng)易等等
這篇文章主要介紹了兩個月面試經(jīng)歷回顧:阿里,攜程,小紅書,美團,網(wǎng)易等等,分享給大家經(jīng)驗,有興趣的可以了解一下2019-06-252019 金三銀四:阿里P9架構的Android大廠面試題總結
面試是一道坎,很多人會恐懼面試,即使是工作很多年的老鳥,可能仍存在面試的焦慮。 今天介紹了阿里P9架構的Android大廠面試題總結的相關資料,小編覺得挺不錯的,現(xiàn)在分2019-05-05剛參加完阿里面試:一面+二面+三面+HR四面(經(jīng)驗總結)
很多人去面試之前都很做足準備,下面就分享一次,從面試中,其實可以看得出來現(xiàn)在的公司對于面試者的知識體系要求,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-04-09- 這篇文章主要介紹了BAT面試中的大數(shù)據(jù)相關問題,涉及大數(shù)據(jù)相關的概念、原理、知識點與算法等問題,需要的朋友可以參考下2019-08-30
- 這篇文章主要介紹了銀行java開發(fā)筆試面試題13道,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-08-27