zoukankan      html  css  js  c++  java
  • Java——银行业务调度系统

    
    需求:

    模拟实现银行业务调度系统逻辑,具体需求如下:

    Ø 银行内有6个业务窗口,1 - 4号窗口为普通窗口,5号窗口为快速窗口,6号窗口为VIP窗口。

    Ø 有三种对应类型的客户:VIP客户,普通客户,快速客户(办理如交水电费、电话费之类业务的客户)。

    Ø 异步随机生成各种类型的客户,生成各类型用户的概率比例为:

            VIP客户 :普通客户 :快速客户  =  1 3

    Ø 客户办理业务所需时间有最大值和最小值,在该范围内随机设定每个VIP客户以及普通客户办理业务所需的时间,快速客户办理业务所需时间为最小值(提示:办理业务的过程可通过线程Sleep的方式模拟)。

    Ø 各类型客户在其对应窗口按顺序依次办理业务。 

    Ø VIP6号)窗口和快速业务(5号)窗口没有客户等待办理业务的时候,这两个窗口可以处理普通客户的业务,而一旦有对应的客户等待办理业务的时候,则优先处理对应客户的业务。

    Ø 随机生成客户时间间隔以及业务办理时间最大值和最小值自定,可以设置。

    Ø 不要求实现GUI,只考虑系统逻辑实现,可通过Log方式展现程序运行结果。

    -------------------------------------------------------------------------------------

    /*

     * 分析:

     *  有三种对应类型的客户:VIP客户,  普通客户,  快速客户。。  异步随机产生各种类型的客户,

     * 各种类型客户在其对应窗口安顺西一次办理业务。。

     *  每一个客户就是由  银行的取号机 产生号码的方式来表示的所以,  要想到用一个号码管理器对象,

     * 让这个号码管理器不断地产生号码,就等于随机生成了客户。

     *  并且  这三类号码  产生的客户都是  相对独立的,  所以本系统要产生三个号码管理器对象,各自

     * 管理一类用户的排队 号码,  这三个号码管理器对象由生成这三个号码管理器对象进行管理,

     * 

     * 各个类型客户在其对应窗口按照顺序依次办理业务,  准确的说  应该是窗口依次  叫号。。

     */

    public class 银行业务调度

    {

    /**

     * @param args

     */ 

    public static void main(String[] args)

    {

    // TODO Auto-generated method stub

    for(int i=1; i<5; i++)

    {

    ServiceWindow commonWindow = new ServiceWindow();

    commonWindow.setWindowId(i);

    commonWindow.start();

    }

    //模拟快速 窗口取号  服务

    ServiceWindow expressWindow = new ServiceWindow();

    expressWindow.setType(CustomerType.EXPRESS);

    expressWindow.start();

    //模拟VIP窗口  服务

    ServiceWindow vipWindow = new ServiceWindow();

    vipWindow.setType(CustomerType.VIP);

    vipWindow.start();


    //制作一个定时器   进行   普通客户叫号(向出号机器要)

    Executors.newScheduledThreadPool(1).scheduleAtFixedRate(

    new Runnable()

    {

    @Override

    public void run()

    {

    // TODO Auto-generated method stub

    Integer number = NumberMachine.getInstance().getCommonManager().generateNewManager();

    System.out.println(number+"  号————普通客户取到号码啦");

    }

    },//命令——执行的任务

    0,//第一次    过多长时间   去执行

    6,//以后每隔多长时间   在执行一次

    TimeUnit.SECONDS);


    //制作一个定时器     快速客户叫号(向出号机器要)

    Executors.newScheduledThreadPool(1).scheduleAtFixedRate(

    new Runnable()

    {

    @Override

    public void run()

    {

    // TODO Auto-generated method stub

    Integer number = NumberMachine.getInstance().getExpressManager().generateNewManager();

    System.out.println(number+"  号————快速客户取到号码啦");

    }

    },

    0,

    6,

    TimeUnit.SECONDS);


    //制作一个定时器       VIP客户叫号(向出号机器要)

    Executors.newScheduledThreadPool(1).scheduleAtFixedRate(

    new Runnable()

    {

    @Override

    public void run()

    {

    // TODO Auto-generated method stub

    Integer number = NumberMachine.getInstance().getVipManager().generateNewManager();

    System.out.println(number+"  号————VIP客户取到号码啦");

    }

    },

    0,

    6,

    TimeUnit.SECONDS);

    }

    }

    -------------------------------------------------------------------------------


    /*

     * 定义一个用户存储上一个客户号码的成员变量

     * 和 用于存储所有等待服务的客户号码的队列集合。

     * 

     * 定义一个产生新号码的方法,  和获取马上要为之服务的号码的方法。  

     * 这俩个方法被不同的线程操作了相同的数据,所以  要进行同步。

     */

    public class NumberManager

    {

    //新取得号码

    private int lastNumber = 1;

    //用于存放   正在等待的    号码

    private List<Integer> queueNumber = new ArrayList<Integer>();

    //客户  取号

    public synchronized Integer generateNewManager()

    {

    queueNumber.add(lastNumber);//将新产生的这个  顾客的  号码加进去

    return lastNumber++;

    }

    //窗口工作人员 获取    号码(客户)

    public synchronized Integer fetchServiceNumber()

    {

    Integer number = null;

    if(queueNumber.size() > 0)

    {

        number = queueNumber.remove(0);

    }

    return number;

    }

    }

    --------------------------------------------------------------------------------


    /*

     * 将NumberMachine类设计成单例。

     * 

     * 定义三个成员变量分别指向三个NumberManager对象,分别表示普通、

     * 快速和VIP客户的号码管理器,定义三个对应的方法来返回这三个NumberManager对象。

     */

    public class NumberMachine

    {

    private NumberManager commonManager = new NumberManager();//普通用户

    private NumberManager expressManager = new NumberManager();//快速用户

    private NumberManager vipManager = new NumberManager();//VIP用户

    public NumberManager getCommonManager()

    {

        return commonManager;

    }

    public NumberManager getExpressManager()

    {

        return expressManager;

    }

    public NumberManager getVipManager()

    {

        return vipManager;

    }

    //开始构造单例

    private NumberMachine(){};

    private static NumberMachine instance = new NumberMachine();

    public static NumberMachine getInstance()

    {

        return instance;

    }

    }

    -------------------------------------------------------------------------------------


    /*

     * 服务窗口,

     */

    public class ServiceWindow

    {

    //窗口类别

    private CustomerType type = CustomerType.COMMON;//默认是普通用户窗口

    //窗口号

    private int windowId =  1;//默认窗口  号 为1

    /*

     * 通过set方法  来设定窗口的类别 和 此窗口的 号   

     * 这样比  用构造函数进行  设定  方便以后 窗口类型和编号  调整 修改

     */

    public void setType(CustomerType type)

    {

        this.type = type;

    }

    public void setWindowId(int windowId)

    {

        this.windowId = windowId;

    }

    /*

     * 该窗口的服务时间区域

     * 可以通过set设定

     */

    private static int MAX_SERVER_TIME = 10000;//服务最长时间  默认设定10秒

    private static int MIN_SERVER_TIME = 1000;//最短时间  默认是1秒

    public static void setMAX_SERVER_TIME(int mAXSERVERTIME)

    {

        MAX_SERVER_TIME = mAXSERVERTIME;

    }

    public static void setMIN_SERVER_TIME(int mINSERVERTIME)

    {

        MIN_SERVER_TIME = mINSERVERTIME;

    }

    //窗口开始取号      根据服务窗口的类别分别循环调用三个不同的方法。

    public void start()

    {

    Executors.newSingleThreadExecutor().execute(

    new Runnable()

    {

    @Override

    public void run()

    {

    //不停地取号
    while(true)
    {
    switch(type)
    {
    case COMMON:
    ServiceWindow.this.CommonServer();
    break;
    case EXPRESS:
    ServiceWindow.this.ExpressServer();
    break;
    case VIP:
    ServiceWindow.this.VipServer();

    break;

    }

    }

    }

    });

    }

    //对普通窗口进行服务

    private void CommonServer()

    {

    String windowName = "第 "windowId +" 号 普通 窗口";

    //获取该类型(普通用户) 的号码

    Integer CommonNumber = NumberMachine.getInstance().getCommonManager().fetchServiceNumber();

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

    if(CommonNumber != null)

    {//该窗口  开始  为  此用户 服务

    System.out.println(windowName+"为第"+CommonNumber+"个普通客户服务");

    long beginTime = System.currentTimeMillis();

    int maxRand = MAX_SERVER_TIME - MIN_SERVER_TIME;

    long serverTime =MIN_SERVER_TIME + new Random().nextInt(maxRand)+1;//服务时间

    try

    {

        Thread.sleep(serverTime);

    }

    catch (InterruptedException e)

    {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    long costTime = System.currentTimeMillis() - beginTime;

    System.out.println(windowName+"为第"+CommonNumber+"个"+type+"服务 ,耗时"+costTime/1000+"秒");

    }

    else

    {

    System.out.println(windowName+"***********没有取到任务,休息1秒");

    try

    {

        Thread.sleep(1000);

    }

    catch (InterruptedException e)

    {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    }

    }


    //对快速客户窗口进行服务

    private void ExpressServer()

    {

    String windowName = "第 "windowId +" 号 "type.toString()+" 窗口";

    //获取(快速用户)的号码

    Integer ExpressNumber = NumberMachine.getInstance().getExpressManager().fetchServiceNumber();

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

    if(ExpressNumber != null)

    {//该窗口  开始  为  此用户 服务

    long beginTime = System.currentTimeMillis();

    try

    {

        Thread.sleep(MIN_SERVER_TIME);

    }

    catch (InterruptedException e)

    {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    long costTime = System.currentTimeMillis() - beginTime;

    System.out.println(windowName+"为第"+ExpressNumber+"个"+type+"服务 ,耗时"+costTime/1000+"秒");

    }

    else

    {

    System.out.println(windowName+"***********没有取到任务,休息1秒");

    try

    {

        Thread.sleep(1000);

    }

    catch (InterruptedException e)

    {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    }

    }

    //对VIP窗口进行服务

    private void VipServer()

    {

    String windowName = "第 "windowId +" 号 "type.toString()+" 窗口";

    //获取(VIP)用户的号码

    Integer VipNumber = NumberMachine.getInstance().getVipManager().fetchServiceNumber();

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

    int maxRand = MAX_SERVER_TIME - MIN_SERVER_TIME;

    long serverTime =MIN_SERVER_TIME + new Random().nextInt(maxRand)+1;//服务时间

    if(VipNumber != null)

    {//该窗口  开始  为  此用户 服务

    long beginTime = System.currentTimeMillis();

    try

    {

        Thread.sleep(serverTime);

    }

    catch (InterruptedException e)

    {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    long costTime = System.currentTimeMillis() - beginTime;

    System.out.println(windowName+"为第"+VipNumber+"个"+type+"服务 ,耗时"+costTime/1000+"秒");

    }

    else

    {

    System.out.println(windowName+"***********没有取到任务,开始为普通客户服务");

    CommonServer();

    }

    }

    }

    -------------------------------------------------------------------------------------

    /*

     * 定义一个枚举类型 存放客户类型

     */

    public enum CustomerType

    {

     COMMON, EXPRESS, VIP;

     

     //获取对应的名称

     public String toString()

     {

      switch(this)

      {

      case COMMON:

       return "普通";

      case EXPRESS:

       return "快速";

      case VIP:

       return name();

     

      }

      return null;

     }

    }


    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    为什么nhibernate 不能保存ontomany的结构
    如何使用 Mmcv.exe 工具来管理群集消息队列资源[转]
    Building an MSMQ Cluster[转]
    XmlSerializerFactory Is Pretty Cool[转]
    Processing Binary Documents Through BizTalk Via Web Services[转]
    获取数据字典
    Using XPaths in Message Assignment[转]
    MSMQ突破4M限制的方法
    XmlSerializerFactory Is Pretty Cool[转]
    BizTalk自定义证书加密/解密pipeline组件开发
  • 原文地址:https://www.cnblogs.com/blogs-chao/p/4764917.html
Copyright © 2011-2022 走看看