Below is the code. The output is 1000, b=1000. I don't understand why m2() runs first every time.
public class TT implements Runnable{
int b = 100;
public synchronized void m1() throws Exception {
b = 1000;
Thread.sleep(100);
System.out.println("b =" + b);
}
public synchronized void m2() throws Exception {
Thread.sleep(2000);
b = 2000;
}
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();// m1() starts
tt.m2();// m2() starts
System.out.println(tt.b);
}
}