黑马程序员技术交流社区

标题: 程序结果分析 [打印本页]

作者: 高双武    时间: 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