1. 當synchronized修飾一個static方法時,多線程下,獲取的是類鎖(即Class本身,注意:不是實例),作用范圍是整個靜態方法,作用的對象是這個類的所有對象。
2. 當synchronized修飾一個非static方法時,多線程下,獲取的是對象鎖(即類的實例對象),作用范圍是整個方法,作用對象是調用該方法的對象。
結論:類鎖和對象鎖不同,他們之間不會產生互斥。
代碼演示:
public class SynchoronizedDemo { //synchronized修飾非靜態方法 public synchronized void function() throws InterruptedException { for (int i = 0; i <3; i++) { Thread.sleep(1000); System.out.println("function running..."); } } //synchronized修飾靜態方法 public static synchronized void staticFunction() throws InterruptedException { for (int i = 0; i < 3; i++) { Thread.sleep(1000); System.out.println("Static function running..."); } } public static void main(String[] args) { final SynchoronizedDemo demo = new SynchoronizedDemo(); Thread t1 = new Thread(new Runnable() { @Override public void run() { try { staticFunction(); } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread t2 = new Thread(new Runnable() { @Override public void run() { try { demo.function(); } catch (InterruptedException e) { e.printStackTrace(); } } }); t1.start(); t2.start(); } }
運行結果:
Static function running...
function running...
function running...
Static function running...
Static function running...
function running...