我实现了一流的下方,得到如下的输出:的java多线程(在一个类中的两个同步的方法)
dsfs2000
2000
b = 1000;
我很奇怪,为什么它不是:
b = 1000;
dsfs2000
2000
由于t.start()
会首先拨打m1()
,m2()
应该等到m1()
完成,为什么m2()
居然先锁定?
public class TT implements Runnable {
int b = 100;
public synchronized void m1() throws Exception{
//Thread.sleep(2000);
b = 1000;
//Thread.sleep(5000);
System.out.println("b = " + b);
}
public synchronized void m2() throws Exception {
Thread.sleep(2500);
b = 2000;
System.out.println("dsfs" + b);
}
public void run() {
try {
m1();
} catch(Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws Exception {
TT tt = new TT();
Thread t = new Thread(tt);
t.start();
tt.m2();
System.out.println(tt.b);
}
}
你在调用t.start(),它会调用线程的run()方法。在run()方法中,您正在调用m1()。由于线程并行执行,因此您直接调用对象的m2(),因此它先执行,然后执行m1()。您可以预测线程的启动行为。如果想验证延迟,则在调用之间放置sysout.currentTimemilliseconds()。 – Shriram
尝试在't.start()'和'tt.m2()之间添加'Thread.sleep(1000)'' –