Synchronize对象锁
生活随笔
收集整理的這篇文章主要介紹了
Synchronize对象锁
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
對(duì)象鎖
多個(gè)線(xiàn)程多個(gè)鎖
多個(gè)線(xiàn)程,每個(gè)線(xiàn)程都可以拿到自己指定的鎖
分別獲得鎖之后,執(zhí)行synchronize方法體的內(nèi)容
Synchronize
取得的鎖,都是對(duì)象鎖
兩個(gè)對(duì)象,線(xiàn)程獲得的就是兩個(gè)不同的鎖
它們之間獨(dú)立執(zhí)行,互不影響
代碼
package com.bjsxt.base.sync002;/*** 關(guān)鍵字synchronized取得的鎖都是對(duì)象鎖,而不是把一段代碼(方法)當(dāng)做鎖,* 所以代碼中哪個(gè)線(xiàn)程先執(zhí)行synchronized關(guān)鍵字的方法,哪個(gè)線(xiàn)程就持有該方法所屬對(duì)象的鎖(Lock),* * 在靜態(tài)方法上加synchronized關(guān)鍵字,表示鎖定.class類(lèi),類(lèi)一級(jí)別的鎖(獨(dú)占.class類(lèi))。* * @author alienware**/ public class MultiThread {private int num = 0;/** static */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) {// 倆個(gè)不同的對(duì)象final MultiThread m1 = new MultiThread();final MultiThread m2 = new MultiThread();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();}}運(yùn)行
并沒(méi)有等待a執(zhí)行完之后,b才執(zhí)行
說(shuō)明
兩個(gè)不同的對(duì)象,就有兩個(gè)不同的鎖
它們之間互不影響
總結(jié)
以上是生活随笔為你收集整理的Synchronize对象锁的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Synchronize使用
- 下一篇: Synchronize类锁