日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

并发编程面试专题

發(fā)布時(shí)間:2023/12/16 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 并发编程面试专题 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1)現(xiàn)在有 T1、T2、T3 三個(gè)線程,你怎樣保證 T2 在 T1 執(zhí)行完后執(zhí)行,T3 在 T2 執(zhí)行完后執(zhí) 行?

這個(gè)線程問題通常會(huì)在第一輪或電話面試階段被問到,目的是檢測(cè)你對(duì)”join”方法是否熟悉。這個(gè)多線程問題比較簡(jiǎn)單,可以用 join 方法實(shí)現(xiàn)。

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

lock 接口在多線程和并發(fā)編程中最大的優(yōu)勢(shì)是它們?yōu)樽x和寫分別提供了鎖,它能滿足你寫像 ConcurrentHashMap 這樣的高性能數(shù)據(jù)結(jié)構(gòu)和有條件的阻塞。Java 線程面試的問題越來 越會(huì)根據(jù)面試者的回答來提問。我強(qiáng)烈建議在你去參加多線程的面試之前認(rèn)真讀一下 Locks,因?yàn)楫?dāng)前其大量用于構(gòu)建電子交易終統(tǒng)的客戶端緩存和交易連接空間。

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

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

4)用 Java 實(shí)現(xiàn)阻塞隊(duì)列。

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

5)用 Java 寫代碼來解決生產(chǎn)者——消費(fèi)者問題。

與上面的問題很類似,但這個(gè)問題更經(jīng)典,有些時(shí)候面試都會(huì)問下面的問題。在 Java 中怎么解決生產(chǎn)者——消費(fèi)者問題,當(dāng)然有很多解決方法,我已經(jīng)分享了一種用阻塞隊(duì)列實(shí)現(xiàn)的方法。有些時(shí)候他們甚至?xí)栐趺磳?shí)現(xiàn)哲學(xué)家進(jìn)餐問題。

6)用 Java 編程一個(gè)會(huì)導(dǎo)致死鎖的程序,你將怎么解決?

這是我最喜歡的 Java 線程面試問題,因?yàn)榧词顾梨i問題在寫多線程并發(fā)程序時(shí)非常普遍, 但是很多侯選者并不能寫 deadlockfree code(無死鎖代碼?),他們很掙扎。只要告訴他 們,你有 N 個(gè)資源和 N 個(gè)線程,并且你需要所有的資源來完成一個(gè)操作。為了簡(jiǎn)單這里的 n 可以替換為 2,越大的數(shù)據(jù)會(huì)使問題看起來更復(fù)雜。通過避免 Java 中的死鎖來得到關(guān)于 死鎖的更多信息。
7) 什么是原子操作,Java 中的原子操作是什么?

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

8) Java 中的 volatile 關(guān)鍵是什么作用?怎樣使用它?在 Java 中它跟 synchronized 方法有什 么不同?
自從 Java 5 和 Java 內(nèi)存模型改變以后,基于 volatile 關(guān)鍵字的線程問題越來越流行。應(yīng)該 準(zhǔn)備好回答關(guān)于 volatile 變量怎樣在并發(fā)環(huán)境中確保可見性。

9) 什么是競(jìng)爭(zhēng)條件?你怎樣發(fā)現(xiàn)和解決競(jìng)爭(zhēng)?
這是一道出現(xiàn)在多線程面試的高級(jí)階段的問題。大多數(shù)的面試官會(huì)問最近你遇到的競(jìng)爭(zhēng)條件,以及你是怎么解決的。有些時(shí)間他們會(huì)寫簡(jiǎn)單的代碼,然后讓你檢測(cè)出代碼的競(jìng)爭(zhēng)條 件。可以參考我之前發(fā)布的關(guān)于 Java 競(jìng)爭(zhēng)條件的文章。在我看來這是最好的 java 線程面試 問題之一,它可以確切的檢測(cè)候選者解決競(jìng)爭(zhēng)條件的經(jīng)驗(yàn),or writing code which is free of data race or anyother race condition。關(guān)于這方面最好的書是《Concurrency practices in Java》。

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

在 UNIX 中你可以使用 kill -3,然后 thread dump 將會(huì)打印日志,在 windows 中你可以使 用”CTRL+Break”。非常簡(jiǎn)單和專業(yè)的線程面試問題,但是如果他問你怎樣分析它,就會(huì)很 棘手。
11) 為什么我們調(diào)用 start()方法時(shí)會(huì)執(zhí)行 run()方法,為什么我們不能直接調(diào)用 run()方法?

這是另一個(gè)非常經(jīng)典的 java 多線程面試問題。這也是我剛開始寫線程程序時(shí)候的困惑。現(xiàn) 在這個(gè)問題通常在電話面試或者是在初中級(jí) Java 面試的第一輪被問到。這個(gè)問題的回答應(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ū)別》這篇文章來獲得更多信息。
12) Java 中你怎樣喚醒一個(gè)阻塞的線程?

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

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

這個(gè)線程問題主要用來檢測(cè)你是否熟悉 JDK5 中的并發(fā)包。這兩個(gè)的區(qū)別是 CyclicBarrier 可 以重復(fù)使用已經(jīng)通過的障礙,而 CountdownLatch 不能重復(fù)使用。
14) 什么是不可變對(duì)象,它對(duì)寫并發(fā)應(yīng)用有什么幫助?

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

15) 你在多線程環(huán)境中遇到的常見的問題是什么?你是怎么解決它的?

多線程和并發(fā)程序中常遇到的有 Memory-interface、競(jìng)爭(zhēng)條件、死鎖、活鎖和饑餓。問題 是沒有止境的,如果你弄錯(cuò)了,將很難發(fā)現(xiàn)和調(diào)試。這是大多數(shù)基于面試的,而不是基于 實(shí)際應(yīng)用的 Java 線程問題。

總結(jié)

以上是生活随笔為你收集整理的并发编程面试专题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。