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.。。。。!!!!!郁闷啊!