问题很多呀 2017-06-02 07:36 采纳率: 0%
浏览 890

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

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);
}
  • 写回答

2条回答 默认 最新

  • Jimson_HE 2017-06-02 08:04
    关注

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

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

    评论

报告相同问题?