Java synchronized 锁住了什么

时间:2022-08-19 13:01:42

Java synchronized 锁住了什么。  

synchronized 有三种使用场景:

  1)是某个对象实例内,synchronized aMethod(){}可以防止多个线程同时访问这个对象的synchronized方法(如果一个对象有多个synchronized方法,只要一个线程访问了其中的一个synchronized方法,其它线程不能同时访问这个对象中任何一个synchronized方法)。这时,不同的对象实例的 synchronized方法是不相干扰的。也就是说,其它线程照样可以同时访问相同类的另一个对象实例中的synchronized方法;

  2)是某个类的范围,synchronized static aStaticMethod{}防止多个线程同时访问这个类中的synchronized static 方法。它可以对类的所有对象实例起作用。

  2、除了方法前用synchronized关键字,synchronized关键字还可以用于方法中的某个区块中,表示只对这个区块的资源实行互斥访问。用法是: synchronized(this){/*区块*/},它的作用域是当前对象;

  3、synchronized关键字是不能继承的,也就是说,基类的方法synchronized f(){} 在继承类中并不自动是synchronized f(){},而是变成了f(){}。继承类需要你显式的指定它的某个方法为synchronized方法

如果这样写:

class SWJProcess extends Thread{

    synchronized boolean initSB()//这样保证不了唯一执行

   {

       ...

   }

}

如果有new出了多个SWJProcess,这个锁不能阻止大家同时执行initSB。

原因:见第一条是"某个对象实例内,synchronized aMethod(){}”, 如果你是不同的对象,不能保证代码唯一执行。

 

解决方法:

   1) 建立静态函数。通过函数来执行这个initSB

          即:增加函数public static SWJProcess  instance() { return SB;}  if(instance() != null) instance().initSB()

 

  2)  建立静态的其它对象,通过其它对象来锁代码。

       即:

    static String myname = "SWJ";

   boolean initSB()//这样保证不了唯一执行

   {

      synchronized(myname)

      {

        ...

      }

  }