互聯(lián)網(wǎng)常見(jiàn)Java編程面試題

互聯(lián)網(wǎng)常見(jiàn)Java編程面試題

長(zhǎng)沙牛耳教育      2022-04-28 02:28:01     10

互聯(lián)網(wǎng)常見(jiàn)Java編程面試題,  concurrenthashmap為何讀不用加鎖  jdk1.7  1)HashEntry中的key、hash、next均為final型,只能表頭插入、刪除結(jié)點(diǎn)  2

課程價(jià)格 請(qǐng)咨詢

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

  concurrenthashmap為何讀不用加鎖

  jdk1.7

  1)HashEntry中的key、hash、next均為final型,只能表頭插入、刪除結(jié)點(diǎn)

  2)HashEntry類的value域被聲明為volatile型

  3)不允許用null作為鍵和值,當(dāng)讀線程讀到某個(gè)HashEntry的value域的值為null時(shí),便知道產(chǎn)生了沖突——發(fā)生了重排序現(xiàn)象(put設(shè)置新value對(duì)象的字節(jié)碼指令重排序),需要加鎖后重新讀入這個(gè)value值

  4)volatile變量count協(xié)調(diào)讀寫線程之間的內(nèi)存可見(jiàn)性,寫操作后修改count,讀操作先讀count,根據(jù)happen-before傳遞性原則寫操作的修改讀操作能夠看到

  jdk1.8

  1)Node的val和next均為volatile型

  2)tabAt和casTabAt對(duì)應(yīng)的unsafe操作實(shí)現(xiàn)了volatile語(yǔ)義

  3.ContextClassLoader(線程上下文類加載器)的作用

  越過(guò)類加載器的雙親委派機(jī)制去加載類,如serviceloader實(shí)現(xiàn)

  使用線程上下文類加載器加載類,要注意保證多個(gè)需要通信的線程間的類加載器應(yīng)該是同一個(gè),防止因?yàn)椴煌念惣虞d器導(dǎo)致類型轉(zhuǎn)換異常(ClassCastException)

  tomcat類加載機(jī)制

  不同應(yīng)用使用不同的webapp類加載器,實(shí)現(xiàn)應(yīng)用隔離的效果,webapp類加載器下面是jsp類加載器

  不同應(yīng)用共享的jar包可以放到Shared類加載器/shared目錄下

  osgi類加載機(jī)制

  osgi類加載模型是網(wǎng)狀的,可以在模塊(Bundle)間互相委托

  osgi實(shí)現(xiàn)模塊化熱部署的關(guān)鍵是自定義類加載器機(jī)制的實(shí)現(xiàn),每個(gè)Bundle都有一個(gè)自己的類加載器,當(dāng)需要更換一個(gè)Bundle時(shí),就把Bundle連同類加載器一起換掉以實(shí)現(xiàn)代碼的熱替換

  當(dāng)收到類加載請(qǐng)求時(shí),osgi將按照下面的順序進(jìn)行類搜索:

  1)將以java.*開(kāi)頭的類委派給父類加載器加載

  2)否則,將委派列表名單(配置文件org.osgi.framework.bootdelegation中定義)內(nèi)的類委派給父類加載器加載

  3)否則,檢查是否在import-Package中聲明,如果是,則委派給Export這個(gè)類的Bundle的類加載器加載

  4)否則,檢查是否在Require-Bundle中聲明,如果是,則將類加載請(qǐng)求委托給required bundle的類加載器

  5)否則,查找當(dāng)前Bundle的ClassPath,使用自己的類加載器加載

  6)否則,查找類是否在自己的Fragment Bundle中,如果在,則委派給Fragment Bundle的類加載器加載

  7)否則,查找Dynamic import-Package(Dynamic import只有在真正用到此Package的時(shí)候才進(jìn)行加載)的Bundle,委派給對(duì)應(yīng)Bundle的類加載器加載

  8)否則,類查找失敗

  如何結(jié)束一個(gè)一直運(yùn)行的線程

  使用退出標(biāo)志,這個(gè)flag變量要多線程可見(jiàn)

  使用interrupt,結(jié)合isInterrupted()使用

  threadlocal使用場(chǎng)景及問(wèn)題

  threadlocal并不能解決多線程共享變量的問(wèn)題,同一個(gè)threadlocal所包含的對(duì)象,在不同的thread中有不同的副本,互不干擾

  用于存放線程上下文變量,方便同一線程對(duì)變量的前后多次讀取,如事務(wù)、數(shù)據(jù)庫(kù)connection連接,在web編程中使用的更多

  問(wèn)題:注意線程池場(chǎng)景使用threadlocal,因?yàn)閷?shí)際變量值存放在了thread的threadlocalmap類型變量中,如果該值沒(méi)有remove,也沒(méi)有先set的話,可能會(huì)得到以前的舊值

  問(wèn)題:注意線程池場(chǎng)景下的內(nèi)存泄露,雖然threadlocal的get/set會(huì)清除key(key為threadlocal的弱引用,value是強(qiáng)引用,導(dǎo)致value不釋放)為null的entry,但是最好remove

  以上就是長(zhǎng)沙牛耳教育java培訓(xùn)機(jī)構(gòu)的小編針對(duì)“互聯(lián)網(wǎng)常見(jiàn)Java編程面試題”的內(nèi)容進(jìn)行的回答,希望對(duì)大家有所幫助,如有疑問(wèn),請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。

Java面試題

培訓(xùn)啦提醒您:交易時(shí)請(qǐng)核實(shí)對(duì)方資質(zhì),對(duì)于過(guò)大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。