黑马程序员——复习银行业务调度系统

来源:互联网 发布:mvp 网络请求 编辑:程序博客网 时间:2024/05/16 14:21

------- android培训java培训、期待与您交流! ----------

 

2013年1月21日 08:14:34

昨天看过视频后,根据笔记写出了银行项目* 就在排队机获取实例对象上栽了跟头

今天凭印象再写一遍

 

想把昨天的代码优化一点,已经优化完成的地方

1、获取号码管理器时动态获取,指定类型,返回对应的管理器

2、为客户服务时也指定类型来提供对应服务,三种服务都调用同一个方法

3、服务时间动态获取,提供服务类型,返回对应服务时间

4、产生客户过程的方法抽取出来,通过传递客户类型来创建对应类型的客户

    //提供获取管理器的方法

    public NumberManager getManagerByType(CustomerType type)

    {

       switch (type)

       {

       default:

       caseCOMMON:

           returnthis.commonManager;

       caseEXPRESS:

           returnthis.expressManager;

       caseVIP:

           returnthis.vipManager;

       }

    }

 

    //开启服务

    publicvoid start()

    {

       //窗口一旦开启就连续提供服务

        while (true)

       {

           //根据窗口类型提供相应服务

           switch (type)

           {

           default:

           caseCOMMON:

              service(CustomerType.COMMON);

              break;

           caseEXPRESS:

              service(CustomerType.EXPRESS);

              break;

           caseVIP:

              service(CustomerType.VIP);

              break;      

           }

       }

    }

    //服务过程,需指定服务类型

    privatevoid service(CustomerType type)

    {

       //获取窗口名称:类型和编号

       String windowName = "第"+windowId+"号"+type+"窗口";

       //从排队机相应的管理器中获取服务对象号码

       Integer customerNum = NumberMachine.getInstance().getManagerByType(type).fetchServiceNum();

       //给出提示信息

       System.out.println(windowName+"正在获取"+type+"任务。。。");

       //判断是否拿到客户好吗

       if (customerNum!=null)

       {

           //开始为客户服务,记录开始时间

           long beginTime = System.currentTimeMillis();

           //给出提示信息

           System.out.println(windowName+"正在为第"+customerNum+"位"+type+"客户办理业务………");

           //模拟服务过程,线程休眠一段服务时间

           try

           {

              Thread.sleep(getServiceTime(type));

           } catch (InterruptedException e)

           {

              e.printStackTrace();

           }

           //计算服务耗时

           long costTime = System.currentTimeMillis() - beginTime;

           //给出服务结束信息

           System.out.println(windowName+"为第"+customerNum+"位"+type+"客户服务结束,耗时"+costTime/1000+"秒!");

       }

       else

       {

           //没有获取到对应任务,给出提示

           System.out.println(windowName+"没有获取到"+type+"任务,暂停服务一秒...");

           try

           {

              Thread.sleep(1000);

           } catch (InterruptedException e)

           {

              e.printStackTrace();

           }

       }

    }

    //根据服务类别不同,返回相应的服务时间

    privatelong getServiceTime(CustomerType type)

    {

       //最大最小服务时间

       int MAX_SERVICE_TIME = 10000;

       int MIN_SERVICE_TIME = 1000;

       //判断业务类型

       switch (type)

       {

       caseEXPRESS:return MIN_SERVICE_TIME;

       default:

       caseCOMMON:

       caseVIP:

           //最大随机时间

           int MAX_RAND = MAX_SERVICE_TIME - MIN_SERVICE_TIME + 1;

           //计算服务时间

           long serviceTime =new Random().nextInt(MAX_RAND) + MIN_SERVICE_TIME;

           return serviceTime;       

       }

    }

}

 

      

       //模拟客户产生

       //普通客户

       Executors.newScheduledThreadPool(1).scheduleAtFixedRate(

              new Runnable()//产生过程

              {                

                  @Override

                  publicvoid run()

                  {

                     //调用客户产生方法,传递客户类型

                     generateCustomers(CustomerType.COMMON);

                  }

              },

              0,//不用延迟

              1,//1秒产生一个

              TimeUnit.SECONDS);

    }

    //产生客户

    privatestaticvoid generateCustomers(CustomerType type)

    {

       //客户拿号过程,拿一个号就是一个客户

       Integer newCustomerNum = NumberMachine.getInstance().getManagerByType(type).generateCustomerNum();

       //给出提示信息

       System.out.println("第"+newCustomerNum+"号"+type+"客户等待服务!!");    

    }

遇到的问题:

    为客户服务的代码中输出的提示信息与调用服务方法时指定的类型一致,快速窗口和vip窗口没有任务时需提供普通服务,这时如果直接调用普通服务方法,输出的信息中VIP窗口就是普通窗口了,怎么加一个方法,动态地输出窗口信息,并且不业务信息冲突呢?

先测试下上面完成的部分吧

怎么全是1号普通呢 还没客户产生呀?

 

对窗口进行单独测试后发现,每次只能运行一个窗口,看了昨天的代码后发现,原来是每个窗口用一个线程,怎么把这个给忘记了????不应该呀

 

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

 

用单独线程运行后正常了

设置窗口号::88

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

88VIP窗口正在获取VIP任务。。。

88VIP窗口没有获取到VIP任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

88VIP窗口正在获取VIP任务。。。

88VIP窗口没有获取到VIP任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

 

综测还算正常,就是没加快速和VIP切换普通的代码

 

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,暂停服务一秒...

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP窗口正在获取VIP任务。。。

4号普通窗口正在获取普通任务。。。

4号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP窗口没有获取到VIP任务,暂停服务一秒...

1号普通客户等待服务!!

1号快速客户等待服务!!

1VIP客户等待服务!!

4号普通窗口正在获取普通任务。。。

4号普通窗口正在为第1位普通客户办理业务………

5号快速窗口正在获取快速任务。。。

5号快速窗口正在为第1位快速客户办理业务………

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP窗口正在获取VIP任务。。。

6VIP窗口正在为第1VIP客户办理业务………

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

2号普通客户等待服务!!

1号普通窗口正在获取普通任务。。。

5号快速窗口为第1位快速客户服务结束,耗时1秒!

2号普通窗口正在获取普通任务。。。

1号普通窗口正在为第2位普通客户办理业务………

5号快速窗口正在获取快速任务。。。

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

2号普通窗口没有获取到普通任务,暂停服务一秒...

5号快速窗口没有获取到快速任务,暂停服务一秒...

3号普通客户等待服务!!

2号快速客户等待服务!!

3号普通窗口正在获取普通任务。。。

3号普通窗口正在为第3位普通客户办理业务………

5号快速窗口正在获取快速任务。。。

5号快速窗口正在为第2位快速客户办理业务………

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

4号普通客户等待服务!!

5号快速窗口为第2位快速客户服务结束,耗时1秒!

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,暂停服务一秒...

2号普通窗口正在获取普通任务。。。

2号普通窗口正在为第4位普通客户办理业务………

5号普通客户等待服务!!

3号快速客户等待服务!!

4号普通窗口为第1位普通客户服务结束,耗时3秒!

4号普通窗口正在获取普通任务。。。

4号普通窗口正在为第5位普通客户办理业务………

5号快速窗口正在获取快速任务。。。

 

 

加上为普通客户服务的代码

 

//没有获取到对应任务,给出提示

             System.out.print(windowName +"没有获取到" + type +"任务,");

             //如果是快速或vip窗口没有任务,就转向普通客户服务

             if (type == CustomerType.EXPRESS || type == CustomerType.VIP)

             {

                System.out.println("现在开始提供普通业务办理。");

                //将窗口类型设置为type+"/普通",在枚举类中添加这个类型

                String str = type +"_COMMON";

                this.setType(CustomerType.valueOf(str));

                //调用普通窗口服务方法

                service(CustomerType.valueOf(str));

       //service(CustomerType.COMMON);

       //本次服务结束后,还要将窗口改为原来的类型

                this.setType(type);

             } else

             //不然就是普通窗口空闲 就休息吧

             {

                System.out.println("暂停服务一秒...");

                try

                {

                    Thread.sleep(1000);

                } catch (InterruptedException e)

                {

                    e.printStackTrace();

                }

             }

         发现打印出来的信息不同步 

 

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,现在开始提供普通业务办理。

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,第5号快速/普通窗口正在获取快速/普通任务。。。

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

暂停服务一秒...

4号普通窗口正在获取普通任务。。。

4号普通窗口没有获取到普通任务,第6VIP窗口正在获取VIP任务。。。

6VIP窗口没有获取到VIP任务,现在开始提供普通业务办理。

6VIP/普通窗口正在获取VIP/普通任务。。。

6VIP/普通窗口没有获取到VIP/普通任务,暂停服务一秒...

5号快速/普通窗口没有获取到快速/普通任务,暂停服务一秒...

暂停服务一秒...

1号普通客户等待服务!!

 

把这部分放进同步代码块中,打印出的信息OK

synchronized(this

6VIP窗口正在获取VIP任务。。。

6VIP窗口没有获取到VIP任务,现在开始提供普通业务办理。

4号普通窗口正在获取普通任务。。。

4号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP/普通窗口正在获取VIP/普通任务。。。

6VIP/普通窗口没有获取到VIP/普通任务,暂停服务一秒...

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

1号普通窗口正在获取普通任务。。。

1号普通窗口没有获取到普通任务,暂停服务一秒...

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,现在开始提供普通业务办理。

5号快速/普通窗口正在获取快速/普通任务。。。

5号快速/普通窗口没有获取到快速/普通任务,暂停服务一秒...

1号普通客户等待服务!!

1号快速客户等待服务!!

1VIP客户等待服务!!

1号普通窗口正在获取普通任务。。。

2号普通窗口正在获取普通任务。。。

2号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP窗口正在获取VIP任务。。。

3号普通窗口正在获取普通任务。。。

4号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

6VIP窗口正在为第1VIP客户办理业务………

5号快速窗口正在获取快速任务。。。

5号快速窗口正在为第1位快速客户办理业务………

1号普通窗口正在为第1位普通客户办理业务………

4号普通窗口没有获取到普通任务,暂停服务一秒...

2号普通客户等待服务!!

2号普通窗口正在获取普通任务。。。

2号普通窗口正在为第2位普通客户办理业务………

4号普通窗口正在获取普通任务。。。

4号普通窗口没有获取到普通任务,暂停服务一秒...

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

5号快速窗口为第1位快速客户服务结束,耗时1秒!

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,现在开始提供普通业务办理。

5号快速/普通窗口正在获取快速/普通任务。。。

5号快速/普通窗口没有获取到快速/普通任务,暂停服务一秒...

3号普通客户等待服务!!

2号快速客户等待服务!!

4号普通窗口正在获取普通任务。。。

4号普通窗口正在为第3位普通客户办理业务………

5号快速窗口正在获取快速任务。。。

5号快速窗口正在为第2位快速客户办理业务………

3号普通窗口正在获取普通任务。。。

3号普通窗口没有获取到普通任务,暂停服务一秒...

4号普通客户等待服务!!

5号快速窗口为第2位快速客户服务结束,耗时1秒!

5号快速窗口正在获取快速任务。。。

5号快速窗口没有获取到快速任务,现在开始提供普通业务办理。

3号普通窗口正在获取普通

 

 

原创粉丝点击