15個Java多線程面試題

2019獨角獸企業重金招聘Python工程師標準>>> hot3.png

在任何Java面試當中多線程和并發方面的問題都是必不可少的一部分。如果你想獲得任何股票投資銀行的前臺資訊職位,那么你應該準備很多關于多線程的問題。在投資銀行業務中多線程和并發是一個非常受歡迎的話題,特別是電子交易發展方面相關的。他們會問面試者很多令人混淆的Java線程問題。面試官只是想確信面試者有足夠的Java線程與并發方面的知識,因為候選人中有很多只浮于表面。用于直接面向市場交易的高容量和低延時的電子交易系統在本質上是并發的。下面這些是我在不同時間不同地點喜歡問的Java線程問題。我沒有提供答案,但只要可能我會給你線索,有些時候這些線索足夠回答問題。現在引用Java5并發包關于并發工具和并發集合的問題正在增多。那些問題中ThreadLocal、Blocking Queue、Counting Semaphore和ConcurrentHashMap比較流行。


15個Java多線程面試題及回答

1)現在有T1、T2、T3三個線程,你怎樣保證T2在T1執行完后執行,T3在T2執行完后執行?

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

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

lock接口在多線程和并發編程中最大的優勢是它們為讀和寫分別提供了鎖,它能滿足你寫像ConcurrentHashMap這樣的高性能數據結構和有條件的阻塞。Java線程面試的問題越來越會根據面試者的回答來提問。我強烈建議在你去參加多線程的面試之前認真讀一下Locks,因為當前其大量用于構建電子交易終統的客戶端緩存和交易連接空間。

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

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

4)用Java實現阻塞隊列。

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

5)用Java寫代碼來解決生產者——消費者問題。

與上面的問題很類似,但這個問題更經典,有些時候面試都會問下面的問題。在Java中怎么解決生產者——消費者問題,當然有很多解決方法,我已經分享了一種用阻塞隊列實現的方法。有些時候他們甚至會問怎么實現哲學家進餐問題。

6)用Java編程一個會導致死鎖的程序,你將怎么解決?

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

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

非常簡單的java線程面試問題,接下來的問題是你需要同步一個原子操作。

8) Java中的volatile關鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?

自從Java 5和Java內存模型改變以后,基于volatile關鍵字的線程問題越來越流行。應該準備好回答關于volatile變量怎樣在并發環境中確保可見性、順序性和一致性。

9) 什么是競爭條件?你怎樣發現和解決競爭?

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

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

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

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

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

12) Java中你怎樣喚醒一個阻塞的線程?

這是個關于線程和阻塞的棘手的問題,它有很多解決方法。如果線程遇到了IO阻塞,我并且不認為有一種方法可以中止線程。如果線程因為調用wait()、sleep()、或者join()方法而導致的阻塞,你可以中斷線程,并且通過拋出InterruptedException來喚醒它。我之前寫的《How to deal with blocking methods in java》有很多關于處理線程阻塞的信息。

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

這個線程問題主要用來檢測你是否熟悉JDK5中的并發包。這兩個的區別是CyclicBarrier可以重復使用已經通過的障礙,而CountdownLatch不能重復使用。

14) 什么是不可變對象,它對寫并發應用有什么幫助?

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

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

多線程和并發程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和饑餓。問題是沒有止境的,如果你弄錯了,將很難發現和調試。這是大多數基于面試的,而不是基于實際應用的Java線程問題。

補充的其它幾個問題:

1) 在java中綠色線程和本地線程區別?

2) 線程與進程的區別?

3) 什么是多線程中的上下文切換?

4)死鎖與活鎖的區別,死鎖與餡餅的區別?

5) Java中用到的線程調度算法是什么?

6) 在Java中什么是線程調度?

7) 在線程中你怎么處理不可捕捉異常?

8) 什么是線程組,為什么在Java中不推薦使用?

9) 為什么使用Executor框架比使用應用創建和管理線程好?

10) 在Java中Executor和Executors的區別?

11) 如何在Windows和Linux上查找哪個線程使用的CPU時間最長?

轉載于:https://my.oschina.net/u/2935389/blog/756031

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/397560.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397560.shtml
英文地址,請注明出處:http://en.pswp.cn/news/397560.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 將3變為03,03 Java序列化引發的血案

1、前言《手冊》第 9 頁 “OOP 規約” 部分有一段關于序列化的約定【強制】當序列化類新增屬性時,請不要修改 serialVersionUID 字段,以避免反序列失敗;如果完全不兼容升級,避免反序列化混亂,那么請修改 serialVersion…

《The Pomodoro Technique》

番茄工作法,專注當下,遠離拖延焦慮癥 簡介What to solveHow to useSome applications自我總結簡介 番茄工作法是簡單易行的時間管理方法,是由弗朗西斯科西里洛于1992年創立的一種相對于GTD更微觀的時間管理方法。 What to solve 各種Deadline…

XCoreRedux框架:Android UI組件化與Redux實踐

XCoreRedux框架:Android UI組件化與Redux實踐 author: 莫川 https://github.com/nuptboyzhb/XCoreRedux源碼Demo:https://github.com/nuptboyzhb/XCoreRedux使用android studio打開該項目。 目錄結構 demo 基于xcore框架寫的一個小demoxcore XCoreRedux核心代碼庫…

Gigaset ME/pure/pro體驗:就是這個德味

Gigaset是何方神圣?可能大多數人都沒有聽過。但如果說起西門子,那各位肯定就會“哦”地一聲明白了。實際上,Gigaset就是西門子旗下的手機品牌,當年世界上第一部數字無繩電話就是該品牌的產物,所以這次Gigaset在智能手機…

java獨步尋花,小班語言《江畔獨步尋花》

小班語言《江畔獨步尋花》活動目標:1、學習古詩,感知和理解古詩描繪的景象。2、感受古詩的文學語言。活動準備:1、古詩《江畔獨步尋花》PPT課件。2、柳條兩枝(一條葉子多的,一條葉子少的)活動過程:一、導入&#xff1a…

linux-shell——02

Linux命令的通用命令格式 :命令字 【選項】 【參數】 選項: 作用:用于調節命令的具體功能"-"引導短格式選項(單個字符) EX:“-l”"--"引導長格式選項(多個字符) EX: "…

IOS 資料備份

2019獨角獸企業重金招聘Python工程師標準>>> 利用本地服務器邊下載視頻邊播放 目前還沒有做好,下面是參考資料,做個備份; 參考資料: http://blog.csdn.net/wxw55/article/details/17557295 http://www.code4app.com/io…

BZOJ 1854: [Scoi2010]游戲( 二分圖最大匹配 )

匈牙利算法..從1~10000依次找增廣路, 找不到就停止, 輸出答案. ----------------------------------------------------------------------------#include<bits/stdc.h>using namespace std;const int MAXL 10009, MAXR 1000009;struct edge {int to;edge* next;} E[MA…

linux adduser mysql,linux獨享初始配置方法(ftp、apache、mysql)

在此我們對您購買的linux獨享服務器的配置方法進行簡單說明&#xff0c;內容涉及ftp、apache、mysql相關配置&#xff0c;希望給您使用中帶來方便。該文章為指導性說明。☆獨立服務器linux系統ftp帳戶的設置方法&#xff1a;1、首先服務器端已經安裝vsftp。2、您可以直接登陸服…

Android下文件的壓縮和解壓(Zip格式)

Zip文件結構 ZIP文件結構如下圖所示&#xff0c; File Entry表示一個文件實體,一個壓縮文件中有多個文件實體。 文件實體由一個頭部和文件數據組&#xff0c;Central Directory由多個File header組成&#xff0c;每個File header都保存一個文件實體的偏移&#xff0c;文件最后由…

快速理解和使用 ES7 await/async

await/async 是 ES7 最重要特性之一&#xff0c;它是目前為止 JS 最佳的異步解決方案了。雖然沒有在 ES2016 中錄入&#xff0c;但很快就到來&#xff0c;目前已經在 ES-Next Stage 4 階段。 直接上例子&#xff0c;比如我們需要按順序獲取&#xff1a;產品數據>用戶數據>…

jdeveloper優化:

D:\jdevstudio10133\jdev\bin\jdev.conf末尾加上下面的AddVMOption -Dsun.java2d.noddrawtrueAddVMOption -Dsun.java2d.ddoffscreenfalse 轉載于:https://www.cnblogs.com/sprinng/p/4780112.html

linux make java版本,告訴make是否在Windows或Linux上運行

更新請閱讀這個類似但更好的答案&#xff1a;https&#xff1a;//stackoverflow.com/a/14777895/938111make (和 gcc )可以使用Cygwin或MinGW在MS-Windows上輕松安裝 .正如ldigas所說&#xff0c; make 可以使用 UNAME:$(shell uname) 檢測平臺(命令 uname 也由Cygwin或MinGW安…

MPI多機器實現并行計算

最近使用一個系統的分布式版本搭建測試環境&#xff0c;該系統是基于MPI實現的并行計算&#xff0c;MPI是傳統基于msg的系統&#xff0c;這個框架非常靈活&#xff0c;對程序的結構沒有太多約束&#xff0c;高效實用簡單&#xff0c;下面是MPI在多臺機器上實現并行計算的過程。…

Jenkins_獲取源碼編譯并啟動服務(二)

一、創建Maven項目二、設置SVN信息三、設置構建觸發器四、設置Maven命令五、設置構建后發郵件信息&#xff08;參考文章一&#xff09;六、設置構建后拷貝文件到遠程機器并執行命令來自為知筆記(Wiz)

php 判斷頁面加載完,所有ajax執行完且頁面加載完判斷

jquery ajax&load 方法導致 js效果不顯示或顯示后由于加載后ajax 重新布局頁面導致效果錯誤。解決思路&#xff1a;需要在ajax get post 或 load 等執行完后再去執行方法就不會由于他們沒執行完導致的最終錯誤。那么首先看load 方法定義&#xff1a;jQuery ajax - load() 方…

正確理解ThreadLocal

想必很多朋友對 ThreadLocal并不陌生&#xff0c;今天我們就來一起探討下ThreadLocal的使用方法和實現原理。首先&#xff0c;本文先談一下對ThreadLocal的理 解&#xff0c;然后根據ThreadLocal類的源碼分析了其實現原理和使用需要注意的地方&#xff0c;最后給出了兩個應用場…

2018.7.10 個人博客文章=利用ORM創建分類和ORM的內置函數

昨天的注冊收尾工作 其實就差了和MySql聯系起來的部分&#xff0c;這部分很簡單&#xff0c;首先要做的就是保存用戶通過from傳送過來的頭像文件&#xff1a; """ 保存頭像文件 """ file request.FILES.get(avatar) file_path os.path.join(st…

python 列表與元組的操作簡介

上一篇&#xff1a;Python 序列通用操作介紹 列表 列表是可變的(mutable)——可以改變列表的內容&#xff0c;這不同于字符串和元組&#xff0c;字符串和元組都是不可變的。接下來討論一下列表所提供的方法。 list函數 可以使用list函數來創建列表&#xff1a; list(Hello) [H,…

mfc嵌入matlab繪圖窗口,將matlab的圖嵌入MFC

【實例簡介】VS調用matlab畫圖模塊編譯成的動態鏈接庫&#xff0c;并在MFC顯示。【實例截圖】【核心代碼】3b0582a3-4ea8-4a61-ba33-e448be563b88└── 將matlab的圖嵌入MFC├── matlab_2010b與VS2008_混合編程的實現.pdf├── TestWithData│ ├── Debug│ │ ├─…