一、结论
被synchronized关键字修饰的代码块在执行过程中也可能被调度,也即被sysnchronized修饰的代码块并不是执行完毕后才会被调度。
二、结论验证
1.用于测试被synchronized修饰的两条语句是否执行完毕后才被调度的runnable.
package synchronizedSwitch;
import java.util.concurrent.atomic.AtomicInteger;
public class SwitchedRunnable implements Runnable{
@Override
public void run() {
for(AtomicInteger count = new AtomicInteger(); count.intValue() < 2;){
synchronized(this){
//测试以下两条语句是否执行完毕后才被调度
System.out.println("线程" + Thread.currentThread().getName() + ", print: " + count.getAndIncrement());
System.out.println("线程" + Thread.currentThread().getName() + ", print: " + count.getAndIncrement());
}
}
}
}
2.main主程序:用1中的runnable分别创建两个对象r1和r2,并使用r1和r2创建两个线程。
package synchronizedSwitch;
public class SynchronizedSwitch {
public static void main(String[] args) {
SwitchedRunnable r1 = new SwitchedRunnable();
SwitchedRunnable r2 = new SwitchedRunnable();
Thread [] thread = new Thread[2];
thread[0] = new Thread(r1, "0");
thread[1] = new Thread(r2, "1");
thread[0].start();
thread[1].start();
}
}
三、测试运行结果
线程0, print: 0
线程1, print: 0
线程0, print: 1
线程1, print: 1
从上述运行结果可知,若被synchronized修饰的代码块在执行完毕后才被调度的结论成立,则在线程0打印出数值0后,会继续打印出数值1,但是从运行结果可以看出:线程0打印出数值0后,synchronized修饰的代码块被调度了,线程1打印出了数值0,所以被synchronized修饰的代码块在执行完毕后才被调度的结论不成立,所以就有了本博文开头处的结论:被sysnchronized修饰的代码块并不是执行完毕后才会被调度。