黑马程序员技术交流社区

标题: 线程居然是从1计数的而不是0. why [打印本页]

作者: 请备注    时间: 2014-4-3 17:10
标题: 线程居然是从1计数的而不是0. why
class Ticket extends Thread
{
        private int tick = 100;
        public void run()
        {
            while(true)
            {
                if(tick>0)
                {
                System.out.println(currentThread().getName()+"sale: "+ tick--);
                }
            }
        }



}

class TicketDemo
{
        public static void main(String[] args)
        {
            Ticket t = new Ticket();
            
            Thread t1 = new Thread(t);
            Thread t2 = new Thread(t);
            Thread t3 = new Thread(t);
            Thread t4 = new Thread(t);
            
            t1.start();
            t2.start();
            t3.start();
            t4.start();


        }
作者: xietansheng    时间: 2014-4-3 17:18
什么叫线程从1计数的而不是0,你不是在这里已经卖过票了吗http://bbs.itheima.com/forum.php?mod=viewthread&tid=112654
作者: 清风有意    时间: 2014-4-3 17:31
这个!楼主!你貌似写得相当不规范!首先明确一下,这里共有几个线程。new了4个线程,和一个Ticket,还有一个主线程。而Ticket其实也是一个线程,只不过你没有开启它 start();如果在t1.start()前面加上t.start()的话就真正有了5个线程。 这里因为Thread也实现了Runnable接口,所以可以将Ticket对象传递给Thread。如果想线程数正确,将继承Thread改成实现Runnable
作者: ╰青青子佩ˊゝ    时间: 2014-4-3 20:10
5点提醒你,希望能帮到你。1,2点为提示你的犯得小错误。
  1. class Ticket extends Thread{
  2.         private int tick = 50;
  3.         public void run()
  4.         {
  5.             while(true)
  6.             {
  7.                 if(tick>0)
  8.                 {//1.下面的currentThread().getName()前忘加Thread了.
  9.                         System.out.println(Thread.currentThread().getName()+"sale: "+ tick--);
  10.                 }//2.这个地方要加break,像你的代码就是死循环。
  11.                 else{
  12.                         break;
  13.                 }
  14.             }
  15.         }
  16. }
  17. class TicketDemo{
  18.         public static void main(String[] args)
  19.     {
  20.         Ticket t = new Ticket();//3.这创建了线程,只是没有开启而已,这个线程名叫Thread-0,所以下面的线程从Thread-1开始
  21.         //4.t.start();就可以开启一个线程,你这是线程中传入了线程
  22.         Thread t1 = new Thread(t);
  23.         Thread t2 = new Thread(t);
  24.         Thread t3 = new Thread(t);
  25.         Thread t4 = new Thread(t);
  26.         //5.可以用下面两行代码通过得到线程名去验证一下。
  27.         //System.out.println(t.toString());//返回Thread[Thread-0,5,main]
  28.        //System.out.println(t1.toString());//返回Thread[Thread-1,5,main]
  29.         t1.start();
  30.         t2.start();
  31.         t3.start();
  32.         t4.start();
  33.     }
  34. }
复制代码

作者: xietansheng    时间: 2014-4-4 15:53
╰青青子佩ˊゝ 发表于 2014-4-3 20:10
5点提醒你,希望能帮到你。1,2点为提示你的犯得小错误。

我也点醒你两点。
1、currentThread().getName()前不加Thread也可以,因为当前类已经继承了Thread,这不属于错误,最多是不规范。
2、没有考虑到线程安全问题,卖出来的票不是按照50到1的降序卖的,必须将“ if (tick>0) { ... } else { break; }”这块代码进行同步锁。而且在while(true){  }中,同步代码块外,最好稍作延时,否则50张票绝大部分瞬间被一个线程抢走,看不出多窗口卖票的效果。
作者: ╰青青子佩ˊゝ    时间: 2014-4-4 17:50
xietansheng 发表于 2014-4-4 15:53
我也点醒你两点。
1、currentThread().getName()前不加Thread也可以,因为当前类已经继承了Thread,这不 ...

嗯,谢了。第二点我知道,这跟你问的没有关系。 你姓谢?




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2