黑马程序员技术交流社区
标题:
程序结果分析
[打印本页]
作者:
高双武
时间:
2011-11-10 13:31
标题:
程序结果分析
package execisetest;
class TicketThread extends Thread{
public static int total=20;
public void run(){
while(this.total>0)
{
System.out.println(TicketThread.currentThread()+"还剩"+total+"张票");
this.total=this.total-1;
}
}
}
public class SaleTicket {
public static void main(String [] args){
TicketThread t1=new TicketThread();
TicketThread t2=new TicketThread();
TicketThread t3=new TicketThread();
t1.start();
t2.start();
t3.start();
}
}
结果
Thread[Thread-0,5,main]还剩20张票
Thread[Thread-0,5,main]还剩19张票
Thread[Thread-0,5,main]还剩18张票
Thread[Thread-0,5,main]还剩17张票
Thread[Thread-0,5,main]还剩16张票
Thread[Thread-0,5,main]还剩15张票
Thread[Thread-0,5,main]还剩14张票
Thread[Thread-0,5,main]还剩13张票
Thread[Thread-0,5,main]还剩12张票
Thread[Thread-0,5,main]还剩11张票
Thread[Thread-0,5,main]还剩10张票
Thread[Thread-1,5,main]还剩20张票
Thread[Thread-1,5,main]还剩8张票
Thread[Thread-1,5,main]还剩7张票
Thread[Thread-1,5,main]还剩6张票
Thread[Thread-1,5,main]还剩5张票
Thread[Thread-1,5,main]还剩4张票
Thread[Thread-1,5,main]还剩3张票
Thread[Thread-1,5,main]还剩2张票
Thread[Thread-1,5,main]还剩1张票
Thread[Thread-2,5,main]还剩12张票
Thread[Thread-0,5,main]还剩8张票
为什么20 12 8出现了两次?每次运行结果可能不一样,但每次都有重复的
作者:
柴永菲
时间:
2011-11-10 13:52
因为假设线程t1运行while(this.total>0)时此时total的值为12当t1运行完while(this.total>0)这条语句时cpu的执行权被t2抢去了,这时线程t2运行,
因为total是三个线程共享的,所以当t2运行while(this.total>0)时total还是12,这时打印出的值为12,还没等t2执行 this.total=this.total-1;
t1又抢到执行权会继续执行他以前没执行的代码此时又输出total的值为12,有重复的结果都是这个道理
不过你可以用同步代码块解决这个问题
class TicketThread extends Thread{
public static int total=20;
Object obj=new Object;
public void run(){
while(true){
synchronized(obj){
if(this.total>0)
{
System.out.println(TicketThread.currentThread()+"还剩"+total+"张票");
this.total=this.total-1;
}
}
}
}
}
不知道我讲清楚没,希望能帮到你
作者:
柴永菲
时间:
2011-11-10 13:54
不好意思上面的那个Object obj=new Object();我少写了一个括号
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2