国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  應(yīng)聘面試  >  Java面試題  > java面試題:java知識(shí)點(diǎn)合集(六)

java面試題:java知識(shí)點(diǎn)合集(六)

來(lái)源:千鋒教育
發(fā)布人:wjy
時(shí)間: 2022-07-11 17:03:00 1657530180

  一. 請(qǐng)談?wù)?ReadWriteLock 和 StampedLock

  1. ReadWriteLock的兩種子鎖

  1.1 ReadWriteLock

  ReadWriteLock 可以實(shí)現(xiàn)多個(gè)讀鎖同時(shí)進(jìn)行,但是讀與寫(xiě)和寫(xiě)于寫(xiě)互斥,只能有一個(gè)寫(xiě)鎖線(xiàn)程在進(jìn)行。

  1.2 StampedLock

  StampedLock是Jdk在1.8提供的一種讀寫(xiě)鎖,相比較ReentrantReadWriteLock性能更好,因?yàn)镽eentrantReadWriteLock在讀寫(xiě)之間是互斥的,使用的是一種悲觀策略,在讀線(xiàn)程特別多的情況下,會(huì)造成寫(xiě)線(xiàn)程處于饑餓狀態(tài),雖然可以在初始化的時(shí)候設(shè)置為true指定為公平,但是吞吐量又下去了,而StampedLock是提供了一種樂(lè)觀策略,更好的實(shí)現(xiàn)讀寫(xiě)分離,并且吞吐量不會(huì)下降。

  2. StampedLock的三種子鎖

  2.1 寫(xiě)鎖writeLock

  writeLock是一個(gè)獨(dú)占鎖寫(xiě)鎖,當(dāng)一個(gè)線(xiàn)程獲得該鎖后,其他請(qǐng)求讀鎖或者寫(xiě)鎖的線(xiàn)程阻塞, 獲取成功后,會(huì)返回一個(gè)stamp(憑據(jù))變量來(lái)表示該鎖的版本,在釋放鎖時(shí)調(diào)用unlockWrite方法傳遞stamp參數(shù)。提供了非阻塞式獲取鎖tryWriteLock。

  2.2 悲觀讀鎖readLock

  readLock是一個(gè)共享讀鎖,在沒(méi)有線(xiàn)程獲取寫(xiě)鎖情況下,多個(gè)線(xiàn)程可以獲取該鎖。如果有寫(xiě)鎖獲取,那么其他線(xiàn)程請(qǐng)求讀鎖會(huì)被阻塞。悲觀讀鎖會(huì)認(rèn)為其他線(xiàn)程可能要對(duì)自己操作的數(shù)據(jù)進(jìn)行修改,所以需要先對(duì)數(shù)據(jù)進(jìn)行加鎖,這是在讀少寫(xiě)多的情況下考慮的。請(qǐng)求該鎖成功后會(huì)返回一個(gè)stamp值,在釋放鎖時(shí)調(diào)用unlockRead方法傳遞stamp參數(shù)。提供了非阻塞式獲取鎖方法tryWriteLock。

  2.3 樂(lè)觀讀鎖tryOptimisticRead

  tryOptimisticRead相對(duì)比悲觀讀鎖,在操作數(shù)據(jù)前并沒(méi)有通過(guò)CAS設(shè)置鎖的狀態(tài),如果沒(méi)有線(xiàn)程獲取寫(xiě)鎖,則返回一個(gè)非0的stamp變量,獲取該stamp后在操作數(shù)據(jù)前還需要調(diào)用validate方法來(lái)判斷期間是否有線(xiàn)程獲取了寫(xiě)鎖,如果是返回值為0則有線(xiàn)程獲取寫(xiě)鎖,如果不是0則可以使用stamp變量的鎖來(lái)操作數(shù)據(jù)。由于tryOptimisticRead并沒(méi)有修改鎖狀態(tài),所以不需要釋放鎖。這是讀多寫(xiě)少的情況下考慮的,不涉及CAS操作,所以效率較高,在保證數(shù)據(jù)一致性上需要復(fù)制一份要操作的變量到方法棧中,并且在操作數(shù)據(jù)時(shí)可能其他寫(xiě)線(xiàn)程已經(jīng)修改了數(shù)據(jù),而我們操作的是方法棧里面的數(shù)據(jù),也就是一個(gè)快照,所以最多返回的不是最新的數(shù)據(jù),但是一致性得到了保證。

java面試題:java知識(shí)點(diǎn)合集(六)

  二. 線(xiàn)程的run()和start()有什么區(qū)別?

  每個(gè)線(xiàn)程都是通過(guò)某個(gè)特定Thread對(duì)象所對(duì)應(yīng)的方法run()來(lái)完成其操作的,run()方法稱(chēng)為線(xiàn)程體。通過(guò)調(diào)用Thread類(lèi)的start()方法來(lái)啟動(dòng)一個(gè)線(xiàn)程。

  start() 方法用于啟動(dòng)線(xiàn)程,run() 方法用于執(zhí)行線(xiàn)程的運(yùn)行時(shí)代碼。run() 可以重復(fù)調(diào)用,而 start() 只能調(diào)用一次。

  start()方法來(lái)啟動(dòng)一個(gè)線(xiàn)程,真正實(shí)現(xiàn)了多線(xiàn)程運(yùn)行。調(diào)用start()方法無(wú)需等待run方法體代碼執(zhí)行完畢,可以直接繼續(xù)執(zhí)行其他的代碼; 此時(shí)線(xiàn)程是處于就緒狀態(tài),并沒(méi)有運(yùn)行。 然后通過(guò)此Thread類(lèi)調(diào)用方法run()來(lái)完成其運(yùn)行狀態(tài), run()方法運(yùn)行結(jié)束, 此線(xiàn)程終止。然后CPU再調(diào)度其它線(xiàn)程。

  run()方法是在本線(xiàn)程里的,只是線(xiàn)程里的一個(gè)函數(shù),而不是多線(xiàn)程的。 如果直接調(diào)用run(),其實(shí)就相當(dāng)于是調(diào)用了一個(gè)普通函數(shù)而已,直接待用run()方法必須等待run()方法執(zhí)行完畢才能執(zhí)行下面的代碼,所以執(zhí)行路徑還是只有一條,根本就沒(méi)有線(xiàn)程的特征,所以在多線(xiàn)程執(zhí)行時(shí)要使用start()方法而不是run()方法。

  三. 為什么調(diào)用start()方法時(shí)會(huì)執(zhí)行run() 方法,為什么不直接調(diào)用run()方法?

  這是另一個(gè)非常經(jīng)典的 java 多線(xiàn)程面試問(wèn)題,而且在面試中會(huì)經(jīng)常被問(wèn)到。很簡(jiǎn)單,但是很多人都會(huì)答不上來(lái)!

  new 一個(gè) Thread,線(xiàn)程進(jìn)入了新建狀態(tài)。調(diào)用 start() 方法,會(huì)啟動(dòng)一個(gè)線(xiàn)程并使線(xiàn)程進(jìn)入了就緒狀態(tài),當(dāng)分配到時(shí)間片后就可以開(kāi)始運(yùn)行了。 start() 會(huì)執(zhí)行線(xiàn)程的相應(yīng)準(zhǔn)備工作,然后自動(dòng)執(zhí)行 run() 方法的內(nèi)容,這是真正的多線(xiàn)程工作。

  而直接執(zhí)行 run() 方法,會(huì)把 run 方法當(dāng)成一個(gè) main 線(xiàn)程下的普通方法去執(zhí)行,并不會(huì)在某個(gè)線(xiàn)程中執(zhí)行它,所以這并不是多線(xiàn)程工作。

  總結(jié): 調(diào)用 start 方法方可啟動(dòng)線(xiàn)程并使線(xiàn)程進(jìn)入就緒狀態(tài),而 run 方法只是 thread 的一個(gè)普通方法調(diào)用,還是在主線(xiàn)程里執(zhí)行。

  四. Synchronized用過(guò)嗎,其原理是什么?

  1. 可重入性

  synchronized的鎖對(duì)象中有一個(gè)計(jì)數(shù)器(recursions變量)會(huì)記錄線(xiàn)程獲得幾次鎖;

  可重入的好處:

  可以避免死鎖;

  可以讓我們更好的封裝代碼;

  synchronized是可重入鎖,每部鎖對(duì)象會(huì)有一個(gè)計(jì)數(shù)器記錄線(xiàn)程獲取幾次鎖,在執(zhí)行完同步代碼塊時(shí),計(jì)數(shù)器的數(shù)量會(huì)-1,直到計(jì)數(shù)器的數(shù)量為0,就釋放這個(gè)鎖。

  2. 不可中斷性

  一個(gè)線(xiàn)程獲得鎖后,另一個(gè)線(xiàn)程想要獲得鎖,必須處于阻塞或等待狀態(tài),如果第一個(gè)線(xiàn)程不釋放鎖,第二個(gè)線(xiàn)程會(huì)一直阻塞或等待,不可被中斷;

  synchronized 屬于不可被中斷;

  Lock lock方法是不可中斷的;

  Lock tryLock方法是可中斷的;

  更多關(guān)于“Java培訓(xùn)”的問(wèn)題,歡迎咨詢(xún)千鋒教育在線(xiàn)名師。千鋒已有十余年的培訓(xùn)經(jīng)驗(yàn),課程大綱更科學(xué)更專(zhuān)業(yè),有針對(duì)零基礎(chǔ)的就業(yè)班,有針對(duì)想提升技術(shù)的好程序員班,高品質(zhì)課程助力你實(shí)現(xiàn)java程序員夢(mèng)想。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
面向?qū)ο缶幊痰奶卣魇鞘裁?請(qǐng)解釋每個(gè)特征

答案:面向?qū)ο缶幊痰奶卣靼ǎ悍庋b(Encapsulation):封裝是將相關(guān)的數(shù)據(jù)和方法組合在一起形成類(lèi)的機(jī)制。它可以隱藏內(nèi)部實(shí)現(xiàn)細(xì)節(jié),只暴露必要的...詳情>>

2023-07-18 13:56:00
容器是什么?如何理解容器

  容器(Container)是一個(gè)廣泛的概念,指的是一種可以容納其他元素或?qū)ο蟮臄?shù)據(jù)結(jié)構(gòu)或抽象概念。在計(jì)算機(jī)科學(xué)中,容器的概念經(jīng)常出現(xiàn)在數(shù)據(jù)結(jié)...詳情>>

2023-05-08 13:41:00
快速通道