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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Y_Y 中级黑马   /  2013-10-29 22:36  /  622 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

public class TT implements Runnable {
int b = 100;

public synchronized void m1() throws Exception{
  //Thread.sleep(2000);
  b = 1000;
  Thread.sleep(1000);
  System.out.println("b = " + b);
}

public synchronized void m2() throws Exception {
  b = 2000;
  Thread.sleep(10500);
  
  System.out.println(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();
  
}
}
程序运行结果是2000
b = 1000,既m2先执行完,再执行m1方法。可2个方法都上锁了,应该是m1执行完才解锁后开始执行M2才对啊?

2 个回复

倒序浏览
其实这个问题很简单,给你分析一下你程序的运行就明白了。
最终的原因是os(操作系统)的调度问题,os决定先把锁给主线程,你这里主线程和子线程都是用的一个锁this。
所以在主线程没有释放锁的时候,因为同步代码块的存在,子线程无法得到锁,就得不到执行权。所以你会发现,程序运行时
先睡眠10500毫秒,然后程序向下执行输出2000.然后程序又睡眠1000毫秒。才输出b=1000...这么说你应该明白了吧。

评分

参与人数 1技术分 +1 收起 理由
周志龙 + 1 赞一个!

查看全部评分

回复 使用道具 举报
哥们,其实你调用m2的是实例对象tt好吧!不是线程。
与你共同学习!{:soso_e141:}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马