1、在Java中Executor和Executors的區別?
Executor是線程池的頂層接口,它的實現類如下圖所示:

Executors是一個類,提供了多個靜態方法,用於生成不同類型的線程池,如下圖所示:

2、在Java中Lock接口比synchronized塊的優勢是什么?你需要實現一個高效的緩存,它允許多個用戶讀,但只允許一個用戶寫,以此來保持它的完整性,你會怎樣去實現它?
lock接口在多線程和並發編程中最大的優勢是它們為讀和寫分別提供了鎖,它能滿足你寫像ConcurrentHashMap這樣的高性能數據結構和有條件的阻塞。
3、說說java線程中wait和sleep方法的不同點?
最大的不同是在等待時wait會釋放鎖,而sleep一直持有鎖。Wait通常被用於線程間交互,sleep通常被用於暫停執行。
4、用Java實現阻塞隊列?
http://blog.csdn.net/sigangjun/article/details/47783529
http://www.jb51.net/article/75986.htm
5、用Java寫一個會導致死鎖的程序。
這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程並發程序時非常普遍,但是很多侯選者並不能寫deadlock free code(無死鎖代碼?),他們很掙扎。只要告訴他們,你有N個資源和N個線程,並且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2,越大的數據會使問題看起來更復雜。通過避免Java中的死鎖來得到關於死鎖的更多信息。
6、什么是原子操作,Java中的原子操作是什么?
如果一段代碼被認為是Atomic,則表示這段代碼在執行過程中,是不能被中斷的。通常來說,原子指令由硬件提供,供軟件來實現原子方法(某個線程進入該方法后,就不會被中斷,直到其執行完成),
在x86 平台上,CPU提供了在指令執行期間對總線加鎖的手段。CPU芯片上有一條引線#HLOCK pin,如果匯編語言的程序中在一條指令前面加上前綴"LOCK",經過匯編以后的機器代碼就使CPU在執行這條指令的時候把#HLOCK pin的電位拉低,持續到這條指令結束時放開,從而把總線鎖住,這樣同一總線上別的CPU就暫時不能通過總線訪問內存了,保證了這條指令在多處理器環境中的原子性。
在java.util.concurrent.atomic包下,提供了四種類型的原子更新類:原子更新基本類型、原子更新數組類型、原子更新引用和原子更新屬性。使用原子方式更新基本類型,共包括3個類:
AtomicBoolean:原子更新布爾變量
AtomicInteger:原子更新整型變量
AtomicLong:原子更新長整型變量
7、在線程中你怎么處理不可捕捉異常?
https://blog.csdn.net/sinat_36265222/article/details/87865973
8、Java中的volatile關鍵是什么作用?怎樣使用它?在Java中它跟synchronized方法有什么不同?
http://www.cnblogs.com/zhengbin/p/5654805.html
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()方法?
\調用start()方法時你將創建新的線程,並且執行在run()方法里的代碼。但是如果你直接調用run()方法,它不會創建新的線程也不會執行調用線程的代碼。
12、Java中你怎樣喚醒一個阻塞的線程?
如果線程遇到了IO阻塞,我並且不認為有一種方法可以中止線程。如果線程因為調用wait()、sleep()、或者join()方法而導致的阻塞,你可以中斷線程,並且通過拋出InterruptedException來喚醒它。我之前寫的《How to deal with blocking methods in java》有很多關於處理線程阻塞的信息。
13、在Java中CycliBarriar和CountdownLatch有什么區別?
區別是CyclicBarrier可以重復使用已經通過的障礙,而CountdownLatch不能重復使用。
14、什么是不可變對象,它對並發應用有什么幫助?不可變對象(Immutable Objects)即對象一旦被創建它的狀態(對象的數據,也即對象屬性值)就不能改變,反之即為可變對象(Mutable Objects)。
不可變對象(Immutable Objects)即對象一旦被創建它的狀態(對象的數據,也即對象屬性值)就不能改變,反之即為可變對象(Mutable Objects)。
不可變對象的類即為不可變類(Immutable Class)。Java平台類庫中包含許多不可變類,如String、基本類型的包裝類、BigInteger和BigDecimal等。
不可變對象天生是線程安全的。它們的常量(域)是在構造函數中創建的。既然它們的狀態無法修改,這些常量永遠不會變。
不可變對象永遠是線程安全的。
只有滿足如下狀態,一個對象才是不可變的;
它的狀態不能在創建后再被修改;
所有域都是final類型;
15、你在多線程環境中遇到的常見的問題是什么?你是怎么解決它的?
多線程和並發程序中常遇到的有Memory-interface、競爭條件、死鎖、活鎖和飢餓。問題是沒有止境的,如果你弄錯了,將很難發現和調試。這是大多數基於面試的,而不是基於實際應用的Java線程問題。
18、什么是多線程中的上下文切換?
https://www.cnblogs.com/szlbm/p/5505707.html
19、死鎖與活鎖的區別,死鎖與飢餓的區別?
https://www.jianshu.com/p/72ce1af4de66
20、什么是線程調度,用到的線程調度算法是什么?
https://www.jianshu.com/p/3f6b26ee51ce
所有面試題:
以上題目均收集自互聯網,部分答案也來自互聯網,版權均屬於原作者
