A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

© 曾欢欢 中级黑马   /  2014-5-6 12:31  /  1194 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 曾欢欢 于 2014-5-7 09:12 编辑

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 {
  b = 2000;
  Thread.sleep(2500);
  System.out.println("new b =" + 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);
}
}
此程序输出结果为
new b = 2000
2000
b=1000
为什么将System.out.println("new b =" + b);注释掉,输出结果变为
1000
b = 1000
为什么不是
2000
b = 1000

2 个回复

倒序浏览
这里有两个线程,一个main线程,一个 t.start();开启的线程。
新线程的启动肯定需要时间,虽然时间很短但是没有main线程直接继续运行来的快,所以是main线程优先进入了m2方法,
由于m2方法是synchronized方法,即使t.start();开启的线程初始化完成了,也要等待锁释放。
等main线程的tt.m2(); 执行完后,因为你注释了打印语句,所以没有输出。

之后执行 t.start();开启的线程,到m1方法,赋值为b=1000之后,sleep了,
这时候main线程执行到了 System.out.println(tt.b);打印出了刚好被m1赋值的b=1000;
main线程执行完之后,m1这边“睡完了”,接着执行输出语句,System.out.println("b = " + b);
所以打印结果是:
1000
b = 1000

评分

参与人数 1技术分 +1 收起 理由
SyouRai_Tsk + 1

查看全部评分

回复 使用道具 举报
受教了,万分感谢
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马