<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            java語言

            高級Java多線程面試題及回答

            時間:2025-03-15 20:01:49 java語言 我要投稿
            • 相關推薦

            高級Java多線程面試題及回答

              在任何Java面試當中多線程和并發方面的問題都是必不可少的一部分。本文是百分網小編搜索整理的關于高級Java多線程面試題及回答(15個),供參考學習,希望對大家有所幫助!

            高級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時間最長?

              拓展閱讀

              Java編程語言

              我對進程、線程的了解,主要是學生時代看過的一本大概叫做“C++面象對象多線程編程”的書,是美國人寫的。后來學Java編程語言,一直是馬馬虎虎,以完成任務為目標,沒有像學C++那樣打實基礎(C++的基礎也忘差不多了,汗)。這不做東西時又碰到麻煩,經過排查解決,有幾個簡單知識點做一下筆記。

              第一個是run()與start()。

              翻翻以前自己寫的代碼,是用start()啟動線程的,這次居然犯糊涂用run()來跑,不出錯才怪呢。相信有不少Java編程語言程序員像我一樣,在不懂的時候,就按個點,查看方法列表,跟據方法名想當然地理解。這種方法可以快速入手做東西,但像多線程這類的東西,還是需要打牢基礎,不然麻煩多多。

              run()只是一個普通方法,是Runnable接口定義的,用來執行線程最終要做的事情的方法,它本身沒有特別之處,就像main方法一樣,啟動一個線程后,run()方法會被調用。所以,run()方法沒有創建多線程,run()方法里的東西還在調用者線程里跑。

              start()方法是Thread類定義的,它是真正負責啟動一個線程的。調用此方法后,將會從線程創建一個新的線程出來(強調從當前線程創建新線程是因為一些屬性比如daemon會被繼承),然后在新線程執行run()方法。

              第二個就是InterruptedException。

              典型地,我們在run()方法中常用while循環,并且每次循環通常有Thread.sleep(long)調用,這個sleep(long)方法會拋出InterruptedException。之前對這個異常的理解有誤,以為這是個“錯誤”,其實這只是表示一個狀態。看官方文檔有點拗口,簡單地說,這個異常被拋出表示線程收到中斷請求(你也可以理解為線程正在被終止,通常是這樣,但不絕對。

              為了線程安全、保證數據的一致性,Java編程語言提倡用溫和手斷中止線程,溫和的意思就是run()方法里的代碼有機會決定什么時候退出),比如外部調用interrupt()來中斷此線程。sleep()收到中斷異常意味著sleep時外部發來了中斷請求信號,這時如果沒有需要善后的操作,就可以退出while循環,結束線程了。

              我以前的代碼是catch掉打一句日志,雖然正常工作了,但是卻是錯誤的。

              第三個是Thread.interrupted()和thread.isInterrupted()的區別(后者thread代表Thread的一個實例)。

              兩者都返回線程的當前狀態,區別在于前者返回當前狀態后,會復會這個狀態。比如Thread.interrupted()得了true,但此后線程狀態被立即置為了false。如果不想改變這一狀態,可以用isInterrupted(),比如Thread.currentThread.isInterrupted()。

              還有就是中斷狀態是會被一些操作改變的,所以不能只用此狀態來斷段線程是否要退出。線程應該另外設置一個退出標記(如果需要控制線程的運行與否的話)。

              希望通過本文的介紹,能夠給你帶來幫助。

            【高級Java多線程面試題及回答】相關文章:

            Java多線程面試題及回答02-21

            高級Java面試題精選06-02

            java的多線程04-09

            java多線程05-11

            高級Java面試題匯總05-27

            java多線程教程04-22

            java語言的多線程04-19

            java多線程介紹05-28

            20個高級Java面試題及答案04-23

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院