复习银行业务调度系统

 

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号普通窗口正在获取普通

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值