溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

synchronized與lock的區(qū)別有哪些

發(fā)布時(shí)間:2020-12-09 15:19:20 來(lái)源:億速云 閱讀:191 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

synchronized與lock的區(qū)別有哪些?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

1,原始構(gòu)成

synchronized是關(guān)鍵字,屬于JVM層面,通過(guò)wait,notify和notifyAll來(lái)調(diào)度線(xiàn)程。

Lock是具體類(lèi),是api層面的鎖。

2,使用方法

synchronized不需要用戶(hù)手動(dòng)去釋放鎖, 當(dāng)synchronized代碼執(zhí)行完后,系統(tǒng)會(huì)自動(dòng)釋放鎖。

Lock需要用戶(hù)手動(dòng)釋放鎖,否則會(huì)出現(xiàn)死鎖現(xiàn)象。需要lock和unlock配合try/finally語(yǔ)句塊來(lái)完成。

3,等待是否中斷

synchronized不可中斷,除非拋出異?;蛘哒_\(yùn)行完畢。

Lock可中斷,可以設(shè)置超時(shí)方法或者調(diào)用中斷方法。

4,加鎖是否公平

synchronized非公平鎖。

Lock默認(rèn)非公平鎖,可指定為公平鎖。

5,鎖綁定多個(gè)條件condition

synchronized沒(méi)有。

Lock用來(lái)分組喚醒需要喚醒的線(xiàn)程,可以精確喚醒,而不是像synchronized一樣要么隨機(jī)喚醒一個(gè)線(xiàn)程,要么全部喚醒。

Demo: 練習(xí)

  多線(xiàn)程之間按順序調(diào)用,實(shí)現(xiàn)A->B->C三個(gè)線(xiàn)程啟動(dòng),要求:AA打印5次,BB打印10次,CC打印15次,重復(fù)10遍。

package com.demo.lock;

import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

class ShareResource{
  int number = 1;
  private Lock lock = new ReentrantLock();
  
  private Condition c1 = lock.newCondition();
  private Condition c2 = lock.newCondition();
  private Condition c3 = lock.newCondition();
  
  public void print5(){
    lock.lock();
    try {
      while(number!=1){
        c1.await();
      }
      for(int i=1;i<=5;i++){
        System.out.println(Thread.currentThread().getName()+"\t"+i);
      }
      number = 2;
      c2.signal();
    } catch (Exception e) {
      e.printStackTrace();
    }finally{
      lock.unlock();
    }
  }
  
  public void print10(){
    lock.lock();
    try {
      while(number!=2){
        c2.await();
      }
      for(int i=1;i<=10;i++){
        System.out.println(Thread.currentThread().getName()+"\t"+i);
      }
      number = 3;
      c3.signal();
    } catch (Exception e) {
      e.printStackTrace();
    }finally{
      lock.unlock();
    }
  }
  
  public void print15(){
    lock.lock();
    try {
      while(number!=3){
        c3.await();
      }
      for(int i=1;i<=15;i++){
        System.out.println(Thread.currentThread().getName()+"\t"+i);
      }
      number = 1;
      c1.signal();
    } catch (Exception e) {
      e.printStackTrace();
    }finally{
      lock.unlock();
    }
  }
}
public class TestReentrantLock {

  public static void main(String[] args) {
    ShareResource shareResource = new ShareResource();
    
    new Thread(()->{
      for(int i=1;i<=10;i++){
        shareResource.print5();
      }
    },"AA").start();
    
    new Thread(()->{
      for(int i=1;i<=10;i++){
        shareResource.print10();
      }
    },"BB").start();
    
    new Thread(()->{
      for(int i=1;i<=10;i++){
        shareResource.print15();
      }
    },"CC").start();
  }
}

看完上述內(nèi)容,你們掌握synchronized與lock的區(qū)別有哪些的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI