黑马程序员技术交流社区
标题:
关于线程问题
[打印本页]
作者:
何创
时间:
2012-12-24 10:15
标题:
关于线程问题
学了好几天 把问题全都积累下来 今天问问大家
下面对段代码为什么输出结果会是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);
}
}
作者:
张胜格
时间:
2012-12-24 10:49
在这个程序中实际上运行了三个线程:主线程、垃圾回收线程和t线程,其中主线程和t线程都对b变量进行了操作,
但主线程打印b的值时,t线程不一定已经执行完了所有的程序,所以打印出来的值取决于线程t执行的位置,你多试几次就会出现2000的情况
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2