Java中synchronized的幾種使用方法_第1頁(yè)
Java中synchronized的幾種使用方法_第2頁(yè)
Java中synchronized的幾種使用方法_第3頁(yè)
Java中synchronized的幾種使用方法_第4頁(yè)
Java中synchronized的幾種使用方法_第5頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第Java中synchronized的幾種使用方法目錄用法簡(jiǎn)介1、修飾普通方法2、修飾靜態(tài)方法修飾普通方法VS修飾靜態(tài)方法3、修飾代碼塊thisVSclass總結(jié)前言:

在Java語(yǔ)言中,保證線程安全性的主要手段是加鎖,而Java中的鎖主要有兩種:synchronized和Lock,我們今天重點(diǎn)來(lái)看一下synchronized的幾種用法。

用法簡(jiǎn)介

使用synchronized無(wú)需手動(dòng)執(zhí)行加鎖和釋放鎖的操作,我們只需要聲明synchronized關(guān)鍵字就可以了,JVM層面會(huì)幫我們自動(dòng)的進(jìn)行加鎖和釋放鎖的操作。synchronized可用于修飾普通方法、靜態(tài)方法和代碼塊,接下來(lái)我們分別來(lái)看。

1、修飾普通方法

synchronized修飾普通方法的用法如下:

/**

*synchronized修飾普通方法

publicsynchronizedvoidmethod(){

//....

}

當(dāng)synchronized修飾普通方法時(shí),被修飾的方法被稱為同步方法,其作用范圍是整個(gè)方法,作用的對(duì)象是調(diào)用這個(gè)方法的對(duì)象。

2、修飾靜態(tài)方法

synchronized修飾靜態(tài)方法和修飾普通方法類似,它的用法如下:

/**

*synchronized修飾靜態(tài)方法

publicstaticsynchronizedvoidstaticMethod(){

//.......

}

當(dāng)synchronized修飾靜態(tài)方法時(shí),其作用范圍是整個(gè)程序,這個(gè)鎖對(duì)于所有調(diào)用這個(gè)鎖的對(duì)象都是互斥的。

所謂的互斥,指的是同一時(shí)間只能有一個(gè)線程能使用,其他線程只能排隊(duì)等待。

修飾普通方法VS修飾靜態(tài)方法

synchronized修飾普通方法和靜態(tài)方法看似相同,但二者完全不同,對(duì)于靜態(tài)方法來(lái)說(shuō)synchronized加鎖是全局的,也就是整個(gè)程序運(yùn)行期間,所有調(diào)用這個(gè)靜態(tài)方法的對(duì)象都是互斥的,而普通方法是針對(duì)對(duì)象級(jí)別的,不同的對(duì)象對(duì)應(yīng)著不同的鎖,比如以下代碼,同樣是調(diào)用兩次方法,但鎖的獲取完全不同

實(shí)現(xiàn)代碼如下:

importjava.time.LocalDateTime;

importjava.util.concurrent.ExecutorService;

importjava.util.concurrent.Executors;

importjava.util.concurrent.TimeUnit;

publicclassSynchronizedUsage{

publicstaticvoidmain(String[]args)throwsInterruptedException{

//創(chuàng)建線程池同時(shí)執(zhí)行任務(wù)

ExecutorServicethreadPool=Executors.newFixedThreadPool(10);

//執(zhí)行兩次靜態(tài)方法

threadPool.execute(()-{

staticMethod();

threadPool.execute(()-{

staticMethod();

//執(zhí)行兩次普通方法

threadPool.execute(()-{

SynchronizedUsageusage=newSynchronizedUsage();

usage.method();

threadPool.execute(()-{

SynchronizedUsageusage2=newSynchronizedUsage();

usage2.method();

*synchronized修飾普通方法

*本方法的執(zhí)行需要3s(因?yàn)橛?s的休眠時(shí)間)

publicsynchronizedvoidmethod(){

System.out.println("普通方法執(zhí)行時(shí)間:"+LocalDateTime.now());

try{

//休眠3s

TimeUnit.SECONDS.sleep(3);

}catch(InterruptedExceptione){

e.printStackTrace();

*synchronized修飾靜態(tài)方法

*本方法的執(zhí)行需要3s(因?yàn)橛?s的休眠時(shí)間)

publicstaticsynchronizedvoidstaticMethod(){

System.out.println("靜態(tài)方法執(zhí)行時(shí)間:"+LocalDateTime.now());

try{

//休眠3s

TimeUnit.SECONDS.sleep(3);

}catch(InterruptedExceptione){

e.printStackTrace();

}

以上程序的執(zhí)行結(jié)果如下:

從上述結(jié)果可以看出,靜態(tài)方法加鎖是全局的,針對(duì)的是所有調(diào)用者;而普通方法加鎖是對(duì)象級(jí)別的,不同的對(duì)象擁有的鎖也不同。

3、修飾代碼塊

我們?cè)谌粘i_發(fā)中,最常用的是給代碼塊加鎖,而不是給方法加鎖,因?yàn)榻o方法加鎖,相當(dāng)于給整個(gè)方法全部加鎖,這樣的話鎖的粒度就太大了,程序的執(zhí)行性能就會(huì)受到影響,所以通常情況下,我們會(huì)使用synchronized給代碼塊加鎖,

它的實(shí)現(xiàn)語(yǔ)法如下:

publicvoidclassMethod()throwsInterruptedException{

//前置代碼...

//加鎖代碼

synchronized(SynchronizedUsage.class){

//......

//后置代碼...

}

從上述代碼我們可以看出,相比于修飾方法,修飾代碼塊需要自己手動(dòng)指定加鎖對(duì)象,加鎖的對(duì)象通常使用this或xxx.class這樣的形式來(lái)表示,比如以下代碼:

//加鎖某個(gè)類

synchronized(SynchronizedUsage.class){

//......

//加鎖當(dāng)前類對(duì)象

synchronized(this){

//......

}

thisVSclass

使用synchronized加鎖this和xxx.class是完全不同的,當(dāng)加鎖this時(shí),表示用當(dāng)前的對(duì)象進(jìn)行加鎖,每個(gè)對(duì)象都對(duì)應(yīng)了一把鎖;而當(dāng)使用xxx.class加鎖時(shí),表示使用某個(gè)類(而非類實(shí)例)來(lái)加鎖,它是應(yīng)用程序級(jí)別的,是全局生效的,

如以下代碼所示:

importjava.time.LocalDateTime;

importjava.util.concurrent.ExecutorService;

importjava.util.concurrent.Executors;

importjava.util.concurrent.TimeUnit;

publicclassSynchronizedUsageBlock{

publicstaticvoidmain(String[]args)throwsInterruptedException{

//創(chuàng)建線程池同時(shí)執(zhí)行任務(wù)

ExecutorServicethreadPool=Executors.newFixedThreadPool(10);

//執(zhí)行兩次synchronized(this)

threadPool.execute(()-{

SynchronizedUsageBlockusage=newSynchronizedUsageBlock();

usage.thisMethod();

threadPool.execute(()-{

SynchronizedUsageBlockusage2=newSynchronizedUsageBlock();

usage2.thisMethod();

//執(zhí)行兩次synchronized(xxx.class)

threadPool.execute(()-{

SynchronizedUsageBlockusage3=newSynchronizedUsageBlock();

usage3.classMethod();

threadPool.execute(()-{

SynchronizedUsageBlockusage4=newSynchronizedUsageBlock();

usage4.classMethod();

*synchronized(this)加鎖

*本方法的執(zhí)行需要3s(因?yàn)橛?s的休眠時(shí)間)

publicvoidthisMethod(){

synchronized(this){

System.out.println("synchronized(this)加鎖:"+LocalDateTime.now());

try{

//休眠3s

TimeUnit.SECONDS.sleep(3);

}catch(InterruptedExceptione){

e.printStackTrace();

*synchronized(xxx.class)加鎖

*本方法的執(zhí)行需要3s(因?yàn)橛?s的休眠時(shí)間)

publicvoidclassMethod(){

synchronized(SynchronizedUsageBlock.class){

System.out.println("synchronized(xxx.class)加鎖:"+LocalDateTime.now());

try{

//休眠3s

TimeUnit.SECONDS.sleep(3);

}catch(InterruptedExceptione

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論