悟空老师,我在做一道面试题遇到一个想不通的地方面试题如下:
public class TestSync2 implements Runnable {
int b = 100;
synchronized void m1() throws InterruptedException {
b = 1000;
Thread.sleep(500); //6
System.out.println("b=" + b);
}
synchronized void m2() throws InterruptedException {
Thread.sleep(250); //5
b = 2000;
}
public static void main(String[] args) throws InterruptedException {
TestSync2 tt = new TestSync2();
Thread t = new Thread(tt); //1
t.start(); //2
tt.m2(); //3
System.out.println("main thread b=" + tt.b); //4
}
@Override
public void run() {
try {
m1();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
这个程序的执行结果为什么会有:
main thread b=1000
b=1000
这种情况呢?
我先说一下我的理解,这道题主要是因为主线程和t线程开始执行顺序不同引起的结果不同,我假设主线程先执行,然后抢到了锁对象(this对象),然后线程睡眠250ms,此时t线程执行m1方法,因为锁对象已经被抢占,故自旋等待主线程释放锁对象,主线程执行完m2方法并释放锁对象,此时b=2000,那么为什么会出现上面main thread b = 1000的结果呢?
希望老师可以解惑。