A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 请备注 中级黑马   /  2014-4-3 17:10  /  974 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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();


        }

5 个回复

倒序浏览
什么叫线程从1计数的而不是0,你不是在这里已经卖过票了吗http://bbs.itheima.com/forum.php?mod=viewthread&tid=112654
回复 使用道具 举报
这个!楼主!你貌似写得相当不规范!首先明确一下,这里共有几个线程。new了4个线程,和一个Ticket,还有一个主线程。而Ticket其实也是一个线程,只不过你没有开启它 start();如果在t1.start()前面加上t.start()的话就真正有了5个线程。 这里因为Thread也实现了Runnable接口,所以可以将Ticket对象传递给Thread。如果想线程数正确,将继承Thread改成实现Runnable

评分

参与人数 1技术分 +1 收起 理由
枫儿 + 1 赞一个!

查看全部评分

回复 使用道具 举报
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. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
何伟超 + 1

查看全部评分

回复 使用道具 举报
╰青青子佩ˊゝ 发表于 2014-4-3 20:10
5点提醒你,希望能帮到你。1,2点为提示你的犯得小错误。

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

嗯,谢了。第二点我知道,这跟你问的没有关系。 你姓谢?
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马