日期:2014-05-20  浏览次数:20699 次

java多线程小问题
各位大大,以下这段程序,在if语句中,“让线程先打印再sleep”和“让线程先sleep再打印”,结果为什么会不同?如果先sleep的话,只有一个线程在跑,why why why。。。急问

class Sell implements Runnable {
int ticket = 50;
String str = "";
public void run() {
while(true) {
synchronized(str) {
if(ticket > 0) {
try {Thread.sleep(100);} catch(Exception e) {}
System.out.println(Thread.currentThread().getName() + " is selling ticket " + ticket--);
//try {Thread.sleep(100);} catch(Exception e) {}
}
}
}
}
}
class TestSell {
public static void main(String args[]) {
Sell s1 = new Sell();
new Thread(s1).start();
new Thread(s1).start();
new Thread(s1).start();
new Thread(s1).start();
}
}
------解决方案--------------------
你这程序始终都会只有一个线程在跑好不,又是死循环的跑,又是加了锁的,同一时间只有一个线程执行
------解决方案--------------------
我在自己机器上跑这段代码,都是多个线程啊,你ticket设大一点,跑跑呢,线程的运行和java虚拟机也有关系吧
------解决方案--------------------
经过测试,结果都是一样的啊...
------解决方案--------------------
    我加大到500时,先休眠的方式也会几个线程都能卖票,但某个线程一旦获得机会,就会很长时间获得运行机会。而后休眠的方法,几个线程获得机会更均匀,每个线程都卖不了10张,其他线程就会得到机会。可能和机器有关系。
------解决方案--------------------
引用:
结果是一样的?????怎么我的机器就是我上面所说的情况!!疯了,难道跟双核有关系?不应该呀。ticket变量的值设到1000,效果也是一样

当然有关系。
------解决方案--------------------
同学,看下你用了  synchronized  

把它去掉,你再试试什么情况了.
------解决方案--------------------
引用:
我加大到500时,先休眠的方式也会几个线程都能卖票,但某个线程一旦获得机会,就会很长时间获得运行机会。而后休眠的方法,几个线程获得机会更均匀,每个线程都卖不了10张,其他线程就会得到机会。可能和机器有关系。

sleep方法不会释放获得的锁,应该是某个线程拿到锁在死循环中一直持有它,释放锁让其他线程执行难道是操作系统的调度策略?
------解决方案--------------------
你可以用wait方法试试
------解决方案--------------------
两种都是多个线程轮着执行,但是一次只有一个线程执行。
------解决方案--------------------
在我机子上运行的效果都一样 四核的机子