大神看过来,这段代码输出什么,为什么?主要是为什么?

public class TestPractise implements Runnable {

private int b = 100;

public synchronized void m1() {
    b = 1000;
    System.out.println("m1: " + b);
}

public synchronized void m2() {
    b = 2000;
    System.out.println("m2:"+b);
}

public void run() {
    m1();
}

public static void main(String[] args) {
    TestPractise tp = new TestPractise();
    Thread t = new Thread(tp);
    t.start();
    tp.m2();

    System.out.println("main: " + tp.b);
}

输出为:m2:2000
main: 2000
m1: 1000

首先你定义的Thread.sleep 是让线程休眠,也就是先执行 t.start(); 线程睡眠 2s 执行 tp.m2(); 线程睡眠1s。
所以先执行m2再执行System.out.println("main: " + tp.b); 最后在三秒线程睡醒后执行m1

为什么先执行m2.。。。。!!!!!郁闷啊!