高薪面试题01—银行业务调度系统

来源:互联网 发布:java测试类 main方法 编辑:程序博客网 时间:2024/05/16 19:32

 

 

package com.isoftstone.interview.bank;import java.util.ArrayList;import java.util.List;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 fetchServerNumber(){Integer number = null;if(queueNumber.size()>0){number = queueNumber.remove(0);//取出集合中的元素}return number;//返回号码}}
package com.isoftstone.interview.bank;public class NumberMachine {private NumberManager commonManager = new NumberManager();private NumberManager expressManager = new NumberManager();private NumberManager vipManager = new NumberManager();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;}}

 


package com.isoftstone.interview.bank;public enum CustomerType {COMMON,EXPRESS,VIP;public String toString(){switch(this){case COMMON:return "普通";case EXPRESS:return "快速";case VIP:return name();}return null;}}

package com.isoftstone.interview.bank;import java.util.Random;import java.util.concurrent.Executors;public class ServiceWindow {private CustomerType type = CustomerType.COMMON;private int windowId = 1;//只获取,因为是变化的public void setType(CustomerType type) {this.type = type;}public void setWindowId(int windowId) {this.windowId = windowId;}public void start(){//线程池,只有一个线程Executors.newSingleThreadExecutor().execute(new Runnable(){public void run(){while(true){switch(type){case COMMON:commonService();break;case EXPRESS:expressService();break;case VIP:vipService();break;}}}});}private void commonService() {String windowName = "第"+windowId+"号"+type+"窗口";Integer number = NumberMachine.getInstance().getCommonManager().fetchServerNumber();System.out.println(windowName+"正在获取任务");if(number != null){System.out.println(windowName+"为第"+number+"个"+"普通"+"客户服务");long beginTime = System.currentTimeMillis();//最大随机数9秒int maxRand = Constants.MAX_SERVICE_TIME - Constants.MIN_SERVICE_TIME;long serveTime = new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;//随机数在1到9秒try {Thread.sleep(serveTime);//普通窗口服务时间} catch (InterruptedException e) {e.printStackTrace();}long costTime = System.currentTimeMillis()-beginTime;System.out.println(windowName+"为第"+number+"个"+"普通"+"客户完成服务,耗时"+costTime/1000+"秒");}else{System.out.println(windowName+"没有取到服务任务,先休息一秒钟");try {Thread.sleep(1000);//暂停1秒} catch (InterruptedException e) {e.printStackTrace();}}}private void expressService() {String windowName = "第"+windowId+"号"+type+"窗口";Integer number = NumberMachine.getInstance().getExpressManager().fetchServerNumber();System.out.println(windowName+"正在获取任务");if(number != null){long beginTime = System.currentTimeMillis();//最大随机数9秒//int maxRand = Constants.MAX_SERVICE_TIME - Constants.MIN_SERVICE_TIME;//long serveTime = new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;//随机数在1到9秒try {Thread.sleep(Constants.MIN_SERVICE_TIME);//快速窗口服务时间} catch (InterruptedException e) {e.printStackTrace();}long costTime = System.currentTimeMillis()-beginTime;System.out.println(windowName+"为第"+number+"个"+type+"客户完成服务,耗时"+costTime/1000+"秒");}else{System.out.println(windowName+"没有取到服务任务!");commonService();//快速窗口没有任务,就看看普通窗口有没有任务}}private void vipService() {String windowName = "第"+windowId+"号"+type+"窗口";//阻塞式方法Integer number = NumberMachine.getInstance().getVipManager().fetchServerNumber();System.out.println(windowName+"正在获取任务");if(number != null){long beginTime = System.currentTimeMillis();//最大随机数9秒int maxRand = Constants.MAX_SERVICE_TIME - Constants.MIN_SERVICE_TIME;long serveTime = new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;//随机数在1到9秒try {Thread.sleep(serveTime);//服务时间} catch (InterruptedException e) {e.printStackTrace();}long costTime = System.currentTimeMillis()-beginTime;System.out.println(windowName+"为第"+number+"个"+type+"客户完成服务,耗时"+costTime/1000+"秒");}else{System.out.println(windowName+"没有取到服务任务!");commonService();//vip窗口没有任务,就看看普通窗口有没有任务}}}


package com.isoftstone.interview.bank;import java.util.concurrent.Executors;import java.util.concurrent.TimeUnit;public class MainClass {public static void main(String[] args) {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();//启动一个快速窗口ServiceWindow vipWindow = new ServiceWindow();vipWindow.setType(CustomerType.VIP);vipWindow.start();//启动一个vip窗口//线程池,一个定时的线程,可以一定频率连续启动Executors.newScheduledThreadPool(1).scheduleAtFixedRate(new Runnable(){public void run(){Integer number = NumberMachine.getInstance().getCommonManager().generateNewManager();System.out.println(number+"号普通客户等待服务");}},0,//初次启动时间Constants.COMMON_CUSTOMER_INTERVAL_TIME, //间隔多长时间TimeUnit.SECONDS //间隔时间的单位);//线程池,一个定时的线程,可以一定频率连续启动Executors.newScheduledThreadPool(1).scheduleAtFixedRate(new Runnable(){public void run(){Integer number = NumberMachine.getInstance().getExpressManager().generateNewManager();System.out.println(number+"号快速客户等待服务");}},0,//初次启动时间Constants.COMMON_CUSTOMER_INTERVAL_TIME * 2, //间隔多长时间TimeUnit.SECONDS //间隔时间的单位);//线程池,一个定时的线程,可以一定频率连续启动Executors.newScheduledThreadPool(1).scheduleAtFixedRate(new Runnable(){public void run(){Integer number = NumberMachine.getInstance().getVipManager().generateNewManager();System.out.println(number+"号vip客户等待服务");}},0,//初次启动时间Constants.COMMON_CUSTOMER_INTERVAL_TIME * 6, //间隔多长时间TimeUnit.SECONDS //间隔时间的单位);}}

 

package com.isoftstone.interview.bank;public class Constants {public static int MAX_SERVICE_TIME = 10000;public static int MIN_SERVICE_TIME = 1000;public static int COMMON_CUSTOMER_INTERVAL_TIME = 1;}


 

 

 

原创粉丝点击