實(shí)例講解Java中的synchronized
一、使用場(chǎng)景
在負(fù)責(zé)后臺(tái)開(kāi)發(fā)的時(shí)候,很多時(shí)候都是提供接口給前端開(kāi)發(fā)人員去調(diào)用,會(huì)遇到這樣的場(chǎng)景:
需要提供一個(gè)領(lǐng)獎(jiǎng)接口,每個(gè)用戶(hù)名只能領(lǐng)取一次,我們可以將成功領(lǐng)取的用戶(hù)在數(shù)據(jù)庫(kù)用個(gè)標(biāo)記保存起來(lái)。如果這個(gè)用戶(hù)再來(lái)領(lǐng)取的時(shí)候,查詢(xún)數(shù)據(jù)庫(kù)看該用戶(hù)是否領(lǐng)取過(guò)。
但是問(wèn)題來(lái)了,假設(shè)用戶(hù)手速很快,極短時(shí)間內(nèi)點(diǎn)了兩次領(lǐng)獎(jiǎng)按鈕(前端沒(méi)有進(jìn)行控制,我們也不能依賴(lài)前端去控制)。那么可能掉了兩次領(lǐng)獎(jiǎng)接口,而且有可能第二次調(diào)用的時(shí)候查詢(xún)數(shù)據(jù)庫(kù)的時(shí)候,第一次領(lǐng)獎(jiǎng)還沒(méi)有執(zhí)行完成更新領(lǐng)獎(jiǎng)標(biāo)記。
這種場(chǎng)景就可以使用到synchronized
二、使用實(shí)例
代碼:
package com.luo.test; public class SynTest { public static void main(String args[]) throws InterruptedException{ SynTest synTest = new SynTest(); synTest.test(); } public void test() throws InterruptedException{ new SynThread1().start(); new SynThread1().start(); } public void syn(String userName) throws Exception { synchronized(userName) { System.out.println("進(jìn)入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); } } class SynThread1 extends Thread { public void run(){ try { syn("luoguohui"); } catch (Exception e) { e.printStackTrace(); } } } }
運(yùn)行結(jié)果:
從結(jié)果來(lái)看,可知道,synchronized起作用了,這里調(diào)用了兩次syn(String userName)方法,期間設(shè)置其停留5秒,但是還是等第一次執(zhí)行完,第二次調(diào)用才進(jìn)入synchronized塊里面的。
為了進(jìn)一步確認(rèn)我們的假設(shè),我們不防把synchronized去掉如下:
public void syn(String userName) throws Exception { // synchronized(userName) { System.out.println("進(jìn)入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); // } }
運(yùn)行結(jié)果:
對(duì)比即可分析出來(lái)了
使用方式從實(shí)例可看出來(lái):
public void syn(String userName) throws Exception { synchronized(userName) { System.out.println("進(jìn)入到同步塊,userName=" + userName); Thread.sleep(5000); //5秒 System.out.println("退出同步塊,userName=" + userName); } }
用synchronized把代碼括起來(lái)。
以上就是實(shí)例講解Java中的synchronized的詳細(xì)內(nèi)容,更多關(guān)于Java synchronized的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
mybatis-plus報(bào)錯(cuò)Not Found TableInfoCache異常問(wèn)題
在集成百度uid-generator過(guò)程中,MyBatis-Plus報(bào)錯(cuò)NotFoundTableInfoCache異常,解決方法:檢查實(shí)體類(lèi)是否繼承了官方model,確保實(shí)體類(lèi)對(duì)應(yīng)的mapper已正確注入,在使用@Component注解時(shí),應(yīng)保證相關(guān)依賴(lài)已注入2024-09-09@Resource和@Autowired兩個(gè)注解的區(qū)別及說(shuō)明
這篇文章主要介紹了@Resource和@Autowired兩個(gè)注解的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06Java實(shí)現(xiàn)多線(xiàn)程模擬龜兔賽跑
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)多線(xiàn)程模擬龜兔賽跑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11SpringBoot搭建Dubbo項(xiàng)目實(shí)現(xiàn)斐波那契第n項(xiàng)詳解
這篇文章主要講解了“SpringBoot+Dubbo怎么實(shí)現(xiàn)斐波那契第N項(xiàng)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)吧2022-06-06Spring Cloud實(shí)戰(zhàn)技巧之使用隨機(jī)端口
這篇文章主要給大家介紹了關(guān)于Spring Cloud實(shí)戰(zhàn)技巧之使用隨機(jī)端口的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。2017-06-06IDEA 單元測(cè)試報(bào)錯(cuò):Class not found:xxxx springb
這篇文章主要介紹了IDEA 單元測(cè)試報(bào)錯(cuò):Class not found:xxxx springboot的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Java設(shè)計(jì)模式中的簡(jiǎn)單工廠(chǎng)模式解析
這篇文章主要介紹了Java設(shè)計(jì)模式中的簡(jiǎn)單工廠(chǎng)模式解析,簡(jiǎn)單工廠(chǎng)模式提供一個(gè)創(chuàng)建對(duì)象實(shí)例的功能,而無(wú)須關(guān)心其具體實(shí)現(xiàn),被創(chuàng)建實(shí)例的類(lèi)型可以是接口、抽象類(lèi),也可以是具體的類(lèi),需要的朋友可以參考下2023-11-11詳解Java Proxy動(dòng)態(tài)代理機(jī)制
今天給大家?guī)?lái)的是關(guān)于Java的相關(guān)知識(shí),文章圍繞著Java動(dòng)態(tài)代理機(jī)制展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06