日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

java中synchronized(同步代码块和同步方法)详解及区别

發布時間:2023/12/10 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java中synchronized(同步代码块和同步方法)详解及区别 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題的由來:

看到這樣一個面試題:

?

1

2

3

4

5

6

//下列兩個方法有什么區別

public synchronized void method1(){}

?

public void method2(){

?synchronized (obj){}

}

synchronized用于解決同步問題,當有多條線程同時訪問共享數據時,如果進行同步,就會發生錯誤,Java提供的解決方案是:只要將操作共享數據的語句在某一時段讓一個線程執行完,在執行過程中,其他線程不能進來執行可以。解決這個問題。這里在用synchronized時會有兩種方式,一種是上面的同步方法,即用synchronized來修飾方法,另一種是提供的同步代碼塊。

這里總感覺怪怪的,這兩種方法有什么區別呢,基礎學得不好,于是就動手做了個簡單的測試,代碼如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

public class SynObj {

??public synchronized void methodA() {

????System.out.println("methodA.....");

????try {

??????Thread.sleep(5000);

????} catch (InterruptedException e) {

??????e.printStackTrace();

????}

??}

?

??public void methodB() {

????synchronized(this) {

??????System.out.pritntln("methodB.....");

????}

??}

?

??public void methodC() {

????String str = "sss";

????synchronized (str) {

??????System.out.println(??? "methodC.....");

????}

??}

}

?

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

public class TestSyn {

??public static void main(String[] args) {

????final SynObj obj = new SynObj();

?

????Thread t1 = new Thread(new Runnable() {

??????@Override

??????public void run() {

????????obj.methodA();

??????}

????});

????t1.start();

?

????Thread t2 = new Thread(new Runnable() {

??????@Override

??????public void run() {

????????obj.methodB();

??????}

????});

????t2.start();

?

????Thread t3 = new Thread(new Runnable() {

??????@Override

??????public void run() {

????????obj.methodC();

??????}

????});

????t3.start();

??}

}

這段小代碼片段打印結果如下:

?

1

2

3

4

methodA.....

methodC.....

//methodB會隔一段時間才會打印出來

methodB.....

這段代碼的打印結果是,methodA…..methodC…..會很快打印出來,methodB…..會隔一段時間才打印出來,那么methodB為什么不能像methodC那樣很快被調用呢?

在啟動線程1調用方法A后,接著會讓線程1休眠5秒鐘,這時會調用方法C,注意到方法C這里用synchronized進行加鎖,這里鎖的對象是str這個字符串對象。但是方法B則不同,是用當前對象this進行加鎖,注意到方法A直接在方法上加synchronized,這個加鎖的對象是什么呢?顯然,這兩個方法用的是一把鎖。

*由這樣的結果,我們就知道這樣同步方法是用什么加鎖的了,由于線程1在休眠,這時鎖還沒釋放,導致線程2只有在5秒之后才能調用方法B,由此,可知兩種加鎖機制用的是同一個鎖對象,即當前對象。

另外,同步方法直接在方法上加synchronized實現加鎖,同步代碼塊則在方法內部加鎖,很明顯,同步方法鎖的范圍比較大,而同步代碼塊范圍要小點,一般同步的范圍越大,性能就越差,一般需要加鎖進行同步的時候,肯定是范圍越小越好,這樣性能更好*。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

總結

以上是生活随笔為你收集整理的java中synchronized(同步代码块和同步方法)详解及区别的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。