java樂(lè)觀鎖代碼 java樂(lè)觀鎖實(shí)現(xiàn)

java中悲觀鎖和樂(lè)觀鎖的區(qū)別

樂(lè)觀鎖和悲觀鎖的區(qū)別如下:

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:空間域名、網(wǎng)頁(yè)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、湖南網(wǎng)站維護(hù)、網(wǎng)站推廣。

1、悲觀鎖是當(dāng)線程拿到資源時(shí),就對(duì)資源上鎖,并在提交后,才釋放鎖資源,其他線程才能使用資源。

2、樂(lè)觀鎖是當(dāng)線程拿到資源時(shí),上樂(lè)觀鎖,在提交之前,其他的鎖也可以操作這個(gè)資源,當(dāng)有沖突的時(shí)候,并發(fā)機(jī)制會(huì)保留前一個(gè)提交,打回后一個(gè)提交,讓后一個(gè)線程重新獲取資源后,再操作,然后提交。和git上傳代碼一樣,兩個(gè)線程都不是直接獲取資源本身,而是先獲取資源的兩個(gè)copy版本,然后在這兩個(gè)copy版本上修改。

3、悲觀鎖和樂(lè)觀鎖在并發(fā)量低的時(shí)候,性能差不多,但是在并發(fā)量高的時(shí)候,樂(lè)觀鎖的性能遠(yuǎn)遠(yuǎn)優(yōu)于悲觀鎖。

4、常用的synchronized是悲觀鎖,lock是樂(lè)觀鎖。

Java鎖有哪些種類,以及區(qū)別

一、公平鎖/非公平鎖

公平鎖是指多個(gè)線程按照申請(qǐng)鎖的順序來(lái)獲取鎖。

非公平鎖是指多個(gè)線程獲取鎖的順序并不是按照申請(qǐng)鎖的順序,有可能后申請(qǐng)的線程比先申請(qǐng)的線程優(yōu)先獲取鎖。有可能,會(huì)造成優(yōu)先級(jí)反轉(zhuǎn)或者饑餓現(xiàn)象。

對(duì)于Java ReentrantLock而言,通過(guò)構(gòu)造函數(shù)指定該鎖是否是公平鎖,默認(rèn)是非公平鎖。非公平鎖的優(yōu)點(diǎn)在于吞吐量比公平鎖大。

對(duì)于Synchronized而言,也是一種非公平鎖。由于其并不像ReentrantLock是通過(guò)AQS的來(lái)實(shí)現(xiàn)線程調(diào)度,所以并沒(méi)有任何辦法使其變成公平鎖。

二、可重入鎖

可重入鎖又名遞歸鎖,是指在同一個(gè)線程在外層方法獲取鎖的時(shí)候,在進(jìn)入內(nèi)層方法會(huì)自動(dòng)獲取鎖。說(shuō)的有點(diǎn)抽象,下面會(huì)有一個(gè)代碼的示例。

對(duì)于Java ReentrantLock而言, 他的名字就可以看出是一個(gè)可重入鎖,其名字是Re entrant Lock重新進(jìn)入鎖。

對(duì)于Synchronized而言,也是一個(gè)可重入鎖。可重入鎖的一個(gè)好處是可一定程度避免死鎖。

synchronized void setA() throws Exception{

Thread.sleep(1000);

setB();

}

synchronized void setB() throws Exception{

Thread.sleep(1000);

}

上面的代碼就是一個(gè)可重入鎖的一個(gè)特點(diǎn),如果不是可重入鎖的話,setB可能不會(huì)被當(dāng)前線程執(zhí)行,可能造成死鎖。

三、獨(dú)享鎖/共享鎖

獨(dú)享鎖是指該鎖一次只能被一個(gè)線程所持有。

共享鎖是指該鎖可被多個(gè)線程所持有。

對(duì)于Java

ReentrantLock而言,其是獨(dú)享鎖。但是對(duì)于Lock的另一個(gè)實(shí)現(xiàn)類ReadWriteLock,其讀鎖是共享鎖,其寫鎖是獨(dú)享鎖。

讀鎖的共享鎖可保證并發(fā)讀是非常高效的,讀寫,寫讀 ,寫寫的過(guò)程是互斥的。

獨(dú)享鎖與共享鎖也是通過(guò)AQS來(lái)實(shí)現(xiàn)的,通過(guò)實(shí)現(xiàn)不同的方法,來(lái)實(shí)現(xiàn)獨(dú)享或者共享。

對(duì)于Synchronized而言,當(dāng)然是獨(dú)享鎖。

四、互斥鎖/讀寫鎖

上面講的獨(dú)享鎖/共享鎖就是一種廣義的說(shuō)法,互斥鎖/讀寫鎖就是具體的實(shí)現(xiàn)。

互斥鎖在Java中的具體實(shí)現(xiàn)就是ReentrantLock

讀寫鎖在Java中的具體實(shí)現(xiàn)就是ReadWriteLock

五、樂(lè)觀鎖/悲觀鎖

樂(lè)觀鎖與悲觀鎖不是指具體的什么類型的鎖,而是指看待并發(fā)同步的角度。

悲觀鎖認(rèn)為對(duì)于同一個(gè)數(shù)據(jù)的并發(fā)操作,一定是會(huì)發(fā)生修改的,哪怕沒(méi)有修改,也會(huì)認(rèn)為修改。因此對(duì)于同一個(gè)數(shù)據(jù)的并發(fā)操作,悲觀鎖采取加鎖的形式。悲觀的認(rèn)為,不加鎖的并發(fā)操作一定會(huì)出問(wèn)題。

樂(lè)觀鎖則認(rèn)為對(duì)于同一個(gè)數(shù)據(jù)的并發(fā)操作,是不會(huì)發(fā)生修改的。在更新數(shù)據(jù)的時(shí)候,會(huì)采用嘗試更新,不斷重新的方式更新數(shù)據(jù)。樂(lè)觀的認(rèn)為,不加鎖的并發(fā)操作是沒(méi)有事情的。

從上面的描述我們可以看出,悲觀鎖適合寫操作非常多的場(chǎng)景,樂(lè)觀鎖適合讀操作非常多的場(chǎng)景,不加鎖會(huì)帶來(lái)大量的性能提升。

悲觀鎖在Java中的使用,就是利用各種鎖。

樂(lè)觀鎖在Java中的使用,是無(wú)鎖編程,常常采用的是CAS算法,典型的例子就是原子類,通過(guò)CAS自旋實(shí)現(xiàn)原子操作的更新。

六、分段鎖

分段鎖其實(shí)是一種鎖的設(shè)計(jì),并不是具體的一種鎖,對(duì)于ConcurrentHashMap而言,其并發(fā)的實(shí)現(xiàn)就是通過(guò)分段鎖的形式來(lái)實(shí)現(xiàn)高效的并發(fā)操作。

我們以ConcurrentHashMap來(lái)說(shuō)一下分段鎖的含義以及設(shè)計(jì)思想,ConcurrentHashMap中的分段鎖稱為Segment,它即類似于HashMap(JDK7與JDK8中HashMap的實(shí)現(xiàn))的結(jié)構(gòu),即內(nèi)部擁有一個(gè)Entry數(shù)組,數(shù)組中的每個(gè)元素又是一個(gè)鏈表;同時(shí)又是一個(gè)ReentrantLock(Segment繼承了ReentrantLock)。

當(dāng)需要put元素的時(shí)候,并不是對(duì)整個(gè)hashmap進(jìn)行加鎖,而是先通過(guò)hashcode來(lái)知道他要放在那一個(gè)分段中,然后對(duì)這個(gè)分段進(jìn)行加鎖,所以當(dāng)多線程put的時(shí)候,只要不是放在一個(gè)分段中,就實(shí)現(xiàn)了真正的并行的插入。

但是,在統(tǒng)計(jì)size的時(shí)候,可就是獲取hashmap全局信息的時(shí)候,就需要獲取所有的分段鎖才能統(tǒng)計(jì)。

分段鎖的設(shè)計(jì)目的是細(xì)化鎖的粒度,當(dāng)操作不需要更新整個(gè)數(shù)組的時(shí)候,就僅僅針對(duì)數(shù)組中的一項(xiàng)進(jìn)行加鎖操作。

七、偏向鎖/輕量級(jí)鎖/重量級(jí)鎖

這三種鎖是指鎖的狀態(tài),并且是針對(duì)Synchronized。在Java

5通過(guò)引入鎖升級(jí)的機(jī)制來(lái)實(shí)現(xiàn)高效Synchronized。這三種鎖的狀態(tài)是通過(guò)對(duì)象監(jiān)視器在對(duì)象頭中的字段來(lái)表明的。

偏向鎖是指一段同步代碼一直被一個(gè)線程所訪問(wèn),那么該線程會(huì)自動(dòng)獲取鎖。降低獲取鎖的代價(jià)。

輕量級(jí)鎖是指當(dāng)鎖是偏向鎖的時(shí)候,被另一個(gè)線程所訪問(wèn),偏向鎖就會(huì)升級(jí)為輕量級(jí)鎖,其他線程會(huì)通過(guò)自旋的形式嘗試獲取鎖,不會(huì)阻塞,提高性能。

重量級(jí)鎖是指當(dāng)鎖為輕量級(jí)鎖的時(shí)候,另一個(gè)線程雖然是自旋,但自旋不會(huì)一直持續(xù)下去,當(dāng)自旋一定次數(shù)的時(shí)候,還沒(méi)有獲取到鎖,就會(huì)進(jìn)入阻塞,該鎖膨脹為重量級(jí)鎖。重量級(jí)鎖會(huì)讓其他申請(qǐng)的線程進(jìn)入阻塞,性能降低。

八、自旋鎖

在Java中,自旋鎖是指嘗試獲取鎖的線程不會(huì)立即阻塞,而是采用循環(huán)的方式去嘗試獲取鎖,這樣的好處是減少線程上下文切換的消耗,缺點(diǎn)是循環(huán)會(huì)消耗CPU。

典型的自旋鎖實(shí)現(xiàn)的例子,可以參考自旋鎖的實(shí)現(xiàn)

java多用戶同時(shí)修改一條數(shù)據(jù)時(shí)樂(lè)觀鎖怎么用的?

你說(shuō)的這個(gè)version是mysql底層的鎖機(jī)制提供的,并不是java提供的。

使用數(shù)據(jù)版本(Version)記錄機(jī)制實(shí)現(xiàn),這是mysql樂(lè)觀鎖最常用的一種實(shí)現(xiàn)方式。所謂的數(shù)據(jù)版本就是給數(shù)據(jù)增加一個(gè)版本標(biāo)識(shí),一般是通過(guò)為數(shù)據(jù)庫(kù)表增加一個(gè)數(shù)字類型的 “version” 字段來(lái)實(shí)現(xiàn)。當(dāng)讀取數(shù)據(jù)時(shí),將version字段的值一同讀出,數(shù)據(jù)每更新一次,對(duì)此version值加1。當(dāng)我們提交更新的時(shí)候,判斷數(shù)據(jù)庫(kù)表對(duì)應(yīng)記錄的當(dāng)前版本信息與第一次取出來(lái)的version值進(jìn)行比對(duì),如果數(shù)據(jù)庫(kù)表當(dāng)前版本號(hào)與第一次取出來(lái)的version值相等,則予以更新,否則認(rèn)為是過(guò)期數(shù)據(jù),版本號(hào)重新讀取再做更新。

分享標(biāo)題:java樂(lè)觀鎖代碼 java樂(lè)觀鎖實(shí)現(xiàn)
本文URL:http://m.kartarina.com/article26/dodeocg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站網(wǎng)站內(nèi)鏈App開(kāi)發(fā)定制網(wǎng)站網(wǎng)站制作網(wǎng)站設(shè)計(jì)

廣告

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

外貿(mào)網(wǎng)站建設(shè)
主站蜘蛛池模板: 国产爆乳无码视频在线观看| 久久精品无码一区二区app| 中文精品无码中文字幕无码专区| 超清无码无卡中文字幕| 久久久无码人妻精品无码| 无码天堂亚洲国产AV| 无码人妻久久久一区二区三区| 无码国产伦一区二区三区视频| 国产免费AV片无码永久免费| 久久精品岛国av一区二区无码| 国产在线精品无码二区二区| 亚洲私人无码综合久久网| 无码AV中文一区二区三区| 亚洲AV蜜桃永久无码精品| 亚洲国产成人精品无码一区二区 | 无码人妻一区二区三区av| 亚洲中文字幕不卡无码| 内射无码专区久久亚洲| 亚洲中文字幕无码亚洲成A人片| 亚洲国产精品无码久久一线 | 精品无码国产自产拍在线观看蜜 | 中国无码人妻丰满熟妇啪啪软件| 无码视频一区二区三区| 亚洲AV无码专区在线亚| 无码久久精品国产亚洲Av影片 | 欧洲Av无码放荡人妇网站| 亚洲国产精品无码专区在线观看| 亚洲AⅤ无码一区二区三区在线| 无码av天天av天天爽| 无码人妻精一区二区三区| 中文字幕无码日韩欧毛| 精品无码AV无码免费专区| 无码人妻丰满熟妇区五十路百度| 亚洲综合无码精品一区二区三区 | 亚洲精品无码乱码成人| 中文字幕人妻无码一区二区三区| 人妻少妇乱子伦无码专区| 日韩av片无码一区二区三区不卡 | 黄桃AV无码免费一区二区三区| 无码任你躁久久久久久老妇| 无码人妻一区二区三区免费视频 |