今天在学java的多线程,照着书上敲了一个简单的售票程序,如下:
public class MultiThread {
public static void main(String args[]){
SellTicket t1 = new SellTicket();
SellTicket t2 = new SellTicket();
new Thread(t1,"售票口1").start();
new Thread(t2,"售票口2").start();
}
}
class SellTicket extends Thread {
private int tickets =5;
public void run(){
while(true){
if(tickets>0){
System.out.println(Thread.currentThread().getName()+"正在出售第:"+tickets+" 张票");
tickets--;
}
}
}
}
一运行,哇,控制台成功打印出来了(没有考虑到程序是否已经运行结束),开心!正打算做下一个小例子,没想到下面懵圈了,
电脑卡死,出于初学者的心理,第一时间以为电脑出问题了,打开任务管理器,查看了一下cpu使用情况,
发现Java(TM) platform SE binary一直在占用百分之九十九的cpu使用时间,怪不得会卡死,
然后将Java(TM) platform SE binary这个进程关了,重新运行了一下售票程序,又卡死了,
没办法,只能百度了,然后对着百度出来的方法试了几个,但还是没能解决问题。
后来无意中把上面那个上面的代码改了一下,如下:
public class SellBook {
public static void main(String args[]){
SellTicket t1 = new SellTicket();
SellTicket t2 = new SellTicket();
new Thread(t1,"售票口1").start();
new Thread(t2,"售票口2").start();
}
}
class SellTicket extends Thread {
private int tickets =5;
boolean flag=true;
public void run(){
while(flag){
if(tickets>0){
System.out.println(Thread.currentThread().getName()+"正在出售第:"+tickets+" 张票");
tickets--;
}
if(tickets<=0){
flag=false;
}
}
}
}
运行了几遍,发现竟然没有卡,而且Java(TM) platform SE binary没有再占用cpu,那么肯定是前面代码的原因才导致卡了的,认真检查了一下,
发现前面的代码中使用了while(true)这个循环,在售空票之后也没有退出该循环,导致程序一致处在这个死循环中,就一直在占用大部分的cpu,从而导致卡死,
下面的代码在票售空后退出了while()循环,自然就不会在卡住了