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)
{
...
}
}