有时,我们经常会碰到这样的代码!
现在有2根线程,其中一根会调用testStatic() , 而另一根会在testStatic未执行结束前调用testNonStatic!
那么,按照多线程同步原则,该对象会在调用testStatic()方法时被锁定,而该方法未结束前如果调用testNonStatic()方法,则必须要等待第一个线程执行完后,才可以执行继续执行!
但是,实际情况是两线程可同时被调用!
区别在于,前者是静态的,不需要实例化即可调用,那么既然连实例化的对象都没创建,何来锁住对象呢!
大家都知道,静态的方法一般都是直接调用“类.方法”来执行的,因此,调用testStatic锁住的其实是类!而该类又不同于其创建的对象!(锁住类不等于锁住该类实例的对象!)
总结:每个class只有一个线程可以执行静态同步方法,每个类的对象,只有一个线程可以执行同步方法!当对象实例调用同步方法,而同步方法中又调用了class的静态同步方法,其实此次调用一共得到了2把锁!
java 代码
- public class A {
- public static synchronized void testStatic() {
- //...
- }
- public synchronized void testNonStatic() {
- //...
- }
- }
现在有2根线程,其中一根会调用testStatic() , 而另一根会在testStatic未执行结束前调用testNonStatic!
那么,按照多线程同步原则,该对象会在调用testStatic()方法时被锁定,而该方法未结束前如果调用testNonStatic()方法,则必须要等待第一个线程执行完后,才可以执行继续执行!
但是,实际情况是两线程可同时被调用!
区别在于,前者是静态的,不需要实例化即可调用,那么既然连实例化的对象都没创建,何来锁住对象呢!
大家都知道,静态的方法一般都是直接调用“类.方法”来执行的,因此,调用testStatic锁住的其实是类!而该类又不同于其创建的对象!(锁住类不等于锁住该类实例的对象!)
总结:每个class只有一个线程可以执行静态同步方法,每个类的对象,只有一个线程可以执行同步方法!当对象实例调用同步方法,而同步方法中又调用了class的静态同步方法,其实此次调用一共得到了2把锁!