9) 什么是競(jìng)爭(zhēng)條件?你怎樣發(fā)現(xiàn)和解決競(jìng)爭(zhēng)?
這是一道出現(xiàn)在多線程面試的高級(jí)階段的問(wèn)題。大多數(shù)的面試官會(huì)問(wèn)最近你遇到的競(jìng)爭(zhēng)條件,以及你是怎么解決的。有些時(shí)間他們會(huì)寫簡(jiǎn)單的代碼,然后讓你檢測(cè)出代碼的競(jìng)爭(zhēng)條件??梢詤⒖嘉抑鞍l(fā)布的關(guān)于Java競(jìng)爭(zhēng)條件的文章。在我看來(lái)這是最好的java線程面試問(wèn)題之一,它可以確切的檢測(cè)候選者解決競(jìng)爭(zhēng)條件的經(jīng)驗(yàn),or writing code which is free of data race or any other race condition。關(guān)于這方面最好的書(shū)是《Concurrency practices in Java》。
10) 你將如何使用thread dump?你將如何分析Thread dump?
在UNIX中你可以使用kill -3,然后thread dump將會(huì)打印日志,在windows中你可以使用”CTRL+Break”。非常簡(jiǎn)單和專業(yè)的線程面試問(wèn)題,但是如果他問(wèn)你怎樣分析它,就會(huì)很棘手。
11) 為什么我們調(diào)用start()方法時(shí)會(huì)執(zhí)行run()方法,為什么我們不能直接調(diào)用run()方法?
這是另一個(gè)非常經(jīng)典的java多線程面試問(wèn)題。這也是我剛開(kāi)始寫線程程序時(shí)候的困惑?,F(xiàn)在這個(gè)問(wèn)題通常在電話面試或者是在初中級(jí)Java面試的第一輪被問(wèn)到。這個(gè)問(wèn)題的回答應(yīng)該是這樣的,當(dāng)你調(diào)用start()方法時(shí)你將創(chuàng)建新的線程,并且執(zhí)行在run()方法里的代碼。但是如果你直接調(diào)用run()方法,它不會(huì)創(chuàng)建新的線程也不會(huì)執(zhí)行調(diào)用線程的代碼。閱讀我之前寫的《start與run方法的區(qū)別》這篇文章來(lái)獲得更多信息。
12) Java中你怎樣喚醒一個(gè)阻塞的線程?
這是個(gè)關(guān)于線程和阻塞的棘手的問(wèn)題,它有很多解決方法。如果線程遇到了IO阻塞,我并且不認(rèn)為有一種方法可以中止線程。如果線程因?yàn)檎{(diào)用wait()、sleep()、或者join()方法而導(dǎo)致的阻塞,你可以中斷線程,并且通過(guò)拋出InterruptedException來(lái)喚醒它。我之前寫的《How to deal with blocking methods in java》有很多關(guān)于處理線程阻塞的信息。
13)在Java中CycliBarriar和CountdownLatch有什么區(qū)別?
這個(gè)線程問(wèn)題主要用來(lái)檢測(cè)你是否熟悉JDK5中的并發(fā)包。這兩個(gè)的區(qū)別是CyclicBarrier可以重復(fù)使用已經(jīng)通過(guò)的障礙,而CountdownLatch不能重復(fù)使用。
14) 什么是不可變對(duì)象,它對(duì)寫并發(fā)應(yīng)用有什么幫助?
另一個(gè)多線程經(jīng)典面試問(wèn)題,并不直接跟線程有關(guān),但間接幫助很多。這個(gè)java面試問(wèn)題可以變的非常棘手,如果他要求你寫一個(gè)不可變對(duì)象,或者問(wèn)你為什么String是不可變的。
15) 你在多線程環(huán)境中遇到的共同的問(wèn)題是什么?你是怎么解決它的?
多線程和并發(fā)程序中常遇到的有Memory-interface、競(jìng)爭(zhēng)條件、死鎖、活鎖和饑餓。問(wèn)題是沒(méi)有止境的,如果你弄錯(cuò)了,將很難發(fā)現(xiàn)和調(diào)試。這是大多數(shù)基于面試的,而不是基于實(shí)際應(yīng)用的Java線程問(wèn)題。
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í)間最長(zhǎng)?
聯(lián)系客服