对象锁和类锁
先來看一段小代碼
public class MutiThread {private int num = 0;public synchronized void printNum(String tag){try {if(tag.equals("a")){num = 100;System.out.println("tag a, set num over!");Thread.sleep(1000);} else {num = 200;System.out.println("tag b, set num over!");}System.out.println("tag " + tag + ", num = " + num);} catch (InterruptedException e) {e.printStackTrace();}}//注意觀察run方法輸出順序public static void main(String[] args) {//兩個不同的對象final MutiThread m1 = new MutiThread();final MutiThread m2 = new MutiThread();Thread t1 = new Thread(new Runnable() {@Overridepublic void run() {m1.printNum("a");}});Thread t2 = new Thread(new Runnable() {@Overridepublic void run() {m2.printNum("b");}});t1.start();t2.start();} }輸出結果
tag a, set num over! tag b, set num over! tag b, num = 200 tag a, num = 100可以看得出來,synchronized鎖住的只是對象,而m1,m2并不是同一個對象,所以這個鎖沒有“鎖住”。
這就是對象鎖
如果在方法上加上static關鍵字,輸出結果正常
tag a, set num over! tag a, num = 100 tag b, set num over! tag b, num = 200說明在靜態方法上加synchronized關鍵字,表示鎖定.class類,類一級別的鎖(獨占.class類)。
超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生總結
- 上一篇: 使类和成员的可访问性最小化
- 下一篇: notify和wait