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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 何创 中级黑马   /  2012-12-24 10:15  /  1151 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

学了好几天 把问题全都积累下来 今天问问大家
下面对段代码为什么输出结果会是1000而不是2000呢?m1这个方法首先把b的值改成了1000了然后开始睡5秒  接着m2先睡2.5秒把b的值给改成了2000 那么打印结果因该为2000才对
,可是结果却是1000.。。
package com.bjsxt.yewei;

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;
}

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);
}
}

评分

参与人数 1技术分 +1 收起 理由
奋斗的青春 + 1 赞一个!

查看全部评分

1 个回复

倒序浏览
在这个程序中实际上运行了三个线程:主线程、垃圾回收线程和t线程,其中主线程和t线程都对b变量进行了操作,
但主线程打印b的值时,t线程不一定已经执行完了所有的程序,所以打印出来的值取决于线程t执行的位置,你多试几次就会出现2000的情况

评分

参与人数 1技术分 +1 收起 理由
奋斗的青春 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马