Java中的樂觀鎖和悲觀鎖簡單介紹-創(chuàng)新互聯(lián)

這篇文章主要介紹“Java中的樂觀鎖和悲觀鎖簡單介紹”,在日常操作中,相信很多人在Java中的樂觀鎖和悲觀鎖簡單介紹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java中的樂觀鎖和悲觀鎖簡單介紹”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

十載的圍場網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整圍場建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)從事“圍場網(wǎng)站設(shè)計”,“圍場網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。

  1、 分類一:樂觀鎖與悲觀鎖

  a)悲觀鎖:認為其他線程會干擾本身線程操作,所以加鎖

  i.具體表現(xiàn)形式:synchronized關(guān)鍵字和lock實現(xiàn)類

  b)樂觀鎖:認為沒有其他線程會影響本身線程操作,所以不加鎖

  i.具體表現(xiàn)形式:java的原子類的遞增操作

  ii.原理:采用cas算法

  c)Cas算法:交換與比較

  i.涉及三個數(shù):需要讀寫的內(nèi)存值V,進行比較的值A(chǔ),要寫入的新值B

  ii.具體操作:若A=V,就用B更新V,否則不進行任何操作

  iii.會用ABA問題:cas算法需要判斷內(nèi)存值V是否發(fā)生變化,如果a值變成b值然后又變回a值,cas算法就會無法判斷,產(chǎn)生錯誤。解決上問題:在變量前添加版本號,將aba變成1a2b3c

  iv.循環(huán)時間長開銷大,因為自旋需要消耗cpu

  v.只能保證一個共享變量的原子操作

  2、 分類二

  a) 重入鎖:支持重進入的鎖,排它鎖

  3、 分類三

  a)讀寫鎖:一對鎖,讀鎖,寫鎖,在同一時刻允許多線程訪問

到此,關(guān)于“Java中的樂觀鎖和悲觀鎖簡單介紹”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

網(wǎng)站名稱:Java中的樂觀鎖和悲觀鎖簡單介紹-創(chuàng)新互聯(lián)
新聞來源:http://muchs.cn/article16/dspddg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、網(wǎng)站設(shè)計、ChatGPT、網(wǎng)站維護軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名