Java Synchronized 遇上 静态/实例方法 、静态/实例变量

同步

1)同步方法

2)同步块  

  21) 实例变量

      22) 类变量

锁定的内容

1)锁定类的某个特定实例

2)锁定类对象(类的所有实例)

 

一。同步类实例:同步方法

public class Demo {     
    
    public synchronized void m1(){     
        //...............     
    }     
    
    public void m2(){     
        //............     
    
        synchronized(this){     
            //.........     
        }     
    
        //........     
    }     
}   

这两种写法的效果是一样的,锁定的都是类实例对象。

  如果有一个实例对象demo,有两个线程: thread1,thread2,都调用了demo 对象,如果 thread1调用了demo.m1(),

则thread2在该时间内不能访问demo.m1() 和 demo.m2(); 因为thread1把demo这个对象的锁使用了,所以无法分给其它线程使用。但是,如果thread1

调用 demo1.m1(), thread2调用 demo2.m1(), 则可以同时进行,因为它们调用的是不同的Demo类对象实例。

 

二。同步类实例:同步块(比同步方法更灵活)

public class Demo {     
    Object a = new Object();     
    Object b = new Object();     
    
    public void m1(){     
        //............     
    
        synchronized(a){     
            //.........     
        }     
    
        //........     
    }     
    
    public void m2(){     
        //............     
    
        synchronized(b){     
            //.........     
        }     
    
        //........     
    }     
}   

  这种情况下,是实现代码块锁定,锁定的对象是 变量 a 或 b; 如果有一个实例对象 demo,另外有两个线程: thread1,thread2,

都调用了demo 对象,那么,在同一时间,如果 thread1调用了demo.m1(),则thread2在该时间内可以访问demo.m2();但不能访问

demo.m1() 的同步块, 因为a被 thread1锁定了。

 

三。锁定静态变量或静态方法

public class Demo{     
    static Object o = new Object();     
    
    public static synchronized void m1() {     
        //....     
    }     
    
    public static void m2() {     
        //...     
        synchronized (Demo.class) {     
            //.....     
        }     
        //.....     
    }     
    
    public static void m3() {     
        //..........     
        try {     
            synchronized (Class.forName("Demo")) {     
              //............     
            }     
        } catch (ClassNotFoundException ex) {     
        }     
        //.............     
    }     
    
    public static void m4() {     
        //............     
       synchronized(o){     
         //........     
       }     
        //..........     
    }     
}   

以上4个方法中实现的效果都是一样的,其锁定的对象都是类Demo,而不是实例对象 ,即在多线程中,其共享的资源是属于类的,而不是属于类实例的。

在这种情况下,如果thread1 访问了这4个方法中的任何一个, 在同一时间内其它的线程都不能访问 这4个方法。

 

posted @ 2014-04-29 00:03  等风来。。  Views(1416)  Comments(0Edit  收藏  举报
------------------------------------------------------------------------------------------------------------ --------------- 欢迎联系 x.guan.ling@gmail.com--------------- ------------------------------------------------------------------------------------------------------------