1)現在有T1、T2、T3三個線程,你怎樣保證T2在T1執行完后執行,T3在T2執行完后執行?
這個多線程問題比較簡單,可以用join方法實現,調用join方法后子線程執行結束之前,主線程會進入到阻態,join方法是通過調用線程的wait方法來達到同步的目的的。例如A線程中調用了B線程的join方法,則相當于在A線程中調用了B線程的wait方法,當B線程執行完(或者到達等待時間),B線程會自動調用自身的notifyAll方法喚醒A線程,從而達到同步的目的。。也可以使用單線程的線程池,并且按照順序submit。
2)在Java中Lock接口比synchronized塊的優勢是什么?你需要實現一個高效的緩存,它允許多個用戶讀,但只允許一個用戶寫,以此來保持它的完整性,你會怎樣去實現它?
lock接口在多線程和并發編程中最大的優勢是它們為讀和寫分別提供了鎖,它能滿足你寫像ConcurrentHashMap這樣的高性能數據結構和有條件的阻塞。Java線程面試的問題越來越會根據面試者的回答來提問。我強烈建議在你去參加多線程的面試之前認真讀一下Locks,因為當前其大量用于構建電子交易終統的客戶端緩存和交易連接空間https://blog.csdn.net/bestone0213/article/details/48974257。
3)在java中wait和sleep方法的不同?
最大的不同是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait通常被用于線程間交互,sleep通常被用于暫停執行。
4)用Java實現阻塞隊列。
這是一個相對艱難的多線程面試問題,它能達到很多的目的。第一,它可以檢測侯選者是否能實際的用Java線程寫程序;第二,可以檢測侯選者對并發場景的理解,并且你可以根據這個問很多問題。如果他用wait()和notify()方法來實現阻塞隊列,你可以要求他用最新的Java 5中的并發類來再寫一次https://www.cnblogs.com/huojg-21442/p/7119727.html。
5)用Java寫代碼來解決生產者——消費者問題。
與上面的問題很類似,但這個問題更經典,有些時候面試都會問下面的問題。在Java中怎么解決生產者——消費者問題,當然有很多解決方法,我已經分享了一種用阻塞隊列實現的方法。有些時候他們甚至會問怎么實現哲學家進餐問題https://blog.csdn.net/u010452388/article/details/82624599。
7) 什么是原子操作,Java中的原子操作是什么?
"原子操作(atomic operation)是不需要synchronized",所謂原子操作是指不會被線程調度機制打斷的操作;這種操作一旦開始,就一直運行到結束,中間不會有任何 context switch;
java中一般事務管理里面用到原子操作。
原子操作可以是一個步驟,也可以是多個操作步驟,但是其順序不可以被打亂,也不可以被切割而只執行其中的一部分,將整個操作視作一個整體是原子性的核心特征;
使用原子操作的好處:
⑴.?性能角度:它執行多次的所消耗的時間遠遠小于由于線程所掛起到恢復所消耗的時間,因此無鎖的CAS操作在性能上要比同步鎖高很多;
⑵.?業務需求:業務本身的需求上,無鎖機制本身就可以滿足我們絕不多數的需求,并且在性能上也可以大大的進行提升。
例子:我們使用的版本控制工具與之其實非常的相似,如果使用鎖來同步,其實就意味著只能同時一個人對該文件進行修改,此時其他人就無法操作文件,如果生活中真正遇到這樣的情況我們一定會覺得非常不方便,而現實中我們其實并不是這樣,我們大家都可以修改這個文件,只是誰提交的早,那么他就把他的代碼成功提交的版本控制服務器上,其實這一步就對應著一個原子操作,而后操作的人往往卻因為沖突而導致提交失敗,此時他必須重新更新代碼進行再次修改,重新提交。
8) Java中的volatile關鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?
自從Java 5和Java內存模型改變以后,基于volatile關鍵字的線程問題越來越流行。應該準備好回答關于volatile變量怎樣在并發環境中確保可見性、順序性和一致性http://www.360doc.com/content/16/0406/12/26211242_548274894.shtml。
9) 什么是競爭條件?你怎樣發現和解決競爭?
這是一道出現在多線程面試的高級階段的問題。大多數的面試官會問最近你遇到的競爭條件,以及你是怎么解決的。有些時間他們會寫簡單的代碼,然后讓你檢測出代碼的競爭條件。可以參考我之前發布的關于Java競爭條件的文章。在我看來這是最好的java線程面試問題之一,它可以確切的檢測候選者解決競爭條件的經驗,or writing code which is free of data race or any other race condition。關于這方面最好的書是《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》有很多關于處理線程阻塞的信息。
14) 什么是不可變對象,它對寫并發應用有什么幫助?
另一個多線程經典面試問題,并不直接跟線程有關,但間接幫助很多。這個java面試問題可以變的非常棘手,如果他要求你寫一個不可變對象,或者問你為什么String是不可變的。
補充的其它幾個問題:
1) 在java中綠色線程和本地線程區別?
2) 線程與進程的區別?
https://www.cnblogs.com/zhuzhu2016/p/5804875.html
3) 什么是多線程中的上下文切換?
https://www.cnblogs.com/xrq730/p/5186609.html
4)死鎖與活鎖的區別,死鎖與餡餅的區別?
5) Java中用到的線程調度算法是什么?
6) 在Java中什么是線程調度?
7) 在線程中你怎么處理不可捕捉異常?
8) 什么是線程組,為什么在Java中不推薦使用?
9) 為什么使用Executor框架比使用應用創建和管理線程好?
10) 在Java中Executor和Executors的區別?
https://blog.csdn.net/qq991029781/article/details/52798249
11) 如何在Windows和Linux上查找哪個線程使用的CPU時間最長?