黑马程序员-----------------7K面试-银行调度

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

银行调度需求:

  • 银行内由6个业务窗口,1-4号窗口为普通窗口,6号为快速窗口,6号为VIP窗口。
  • 有三种对应类型的客户:VIP客户,普通客户,快速客户(办理如交水电费,电话费之类业务的客户)
  • 异步随机生成各类型的客户,生成各类型用户的概率比例为:VIP客户:普通客户:快速客户=1:6:3.
  • 客户办理业务所需时间有最大值和最小值,在该范围内随机设定每个VIP客户以及普通客户办理业务所需时间,快速客户办理业务所需时间为最小值。
  • 各类型客户在其对应窗口按顺序依次办理业务。
  • 当VIP窗口和快速业务窗口没有客户等待办理业务的时候,这两个窗口可以处理普通客户的业务,而一旦有对应的客户等待办理业务的时候,则优先处理对应客户的业务。
  • 随机生成客户时间间隔以及业务办理时间最大值和最小值自定,可以设置。
  • 不要求实现GUI,只考虑系统逻辑实现,通过LOG方式展现程序运行结果
分析设计:

  • 有三种对应类型的客户:VIP客户,普通客户,快速客户,异步随机生成各种类型客户,各类型客户在其对应窗口按顺序依次办理业务。不同的客户在到银行时都会获取一个独立的号码,由于有三种类型的客户因此号码也分为三种由一个号码管理器管理号码
  • 各类型客户在其对应窗口按顺序依次办理业务,各个窗口依次叫号。每一个服务窗口需要正确叫号
  • 首先需要一个号码管理器(NumberMachine)管理号码(NumberManager)
package com.leo.bank;

import java.util.*;

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)类

package com.leo.bank;

public class NumberMachine {
	private NumberManager commonManager = new NumberManager();//普通客户号码
	private NumberManager VipManager = new NumberManager();//VIP客户号码
	private NumberManager expressManager = new NumberManager();//快速客户号码
	
	public NumberManager getCommonManager() {
		return commonManager;
	}
	public NumberManager getVipManager() {
		return VipManager;
	}
	public NumberManager getExpressManager() {
		return expressManager;
	}
	//创建单列方法管理三种类型号码
	private NumberMachine(){}
	public static NumberMachine getInstance(){
		return instance;
	}
	private static NumberMachine instance = new NumberMachine();
}

接下来需要一个客户类型的枚举类(CustomerType)

package com.leo.bank;

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

当成功取号以后,就需要一个银行服务窗口(ServiceWindow)类叫号服务。

package com.leo.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;
}

package com.leo.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.newSingleThreadScheduledExecutor().execute(
			new Runnable(){
				public void run(){
					while(true){
						switch(type){
							case COMMON:
							commonService();
								break;
							case VIP:
							vipService();
								break;
							case EXPRESS:
								expressService();
								break;
						}
						
					}
				}
			}		
		);
	}
	private void vipService() {
		String windowName = "第"+windowID+"号"+type+"窗口";
		System.out.println(windowName+"正在获取任务");
		Integer number = NumberMachine.getInstance().getVipManager().fetchServiceNumber();//获取客户号码
		if(number!=null){
			System.out.println("第"+windowName+"号窗口正在为"+number+"VIP客户服务");
			long beginTime = System.currentTimeMillis();
			//int maxRand = Constants.MAX_SERVICE_TIME-Constants.MIN_SERVICE_TIME;
			//long serviceTime =new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;
			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 expressService() {
		String windowName = "第"+windowID+"号"+type+"窗口";
		System.out.println(windowName+"正在获取任务");
		Integer number = NumberMachine.getInstance().getExpressManager().fetchServiceNumber();
		if(number!=null){
			System.out.println("第"+windowName+"号窗口正在为"+number+"快速客户服务");
			long beginTime = System.currentTimeMillis();
			//int maxRand = Constants.MAX_SERVICE_TIME-Constants.MIN_SERVICE_TIME;
			//long serviceTime =new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;
			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 commonService() {
		String windowName = "第"+windowID+"号"+type+"窗口";
		System.out.println(windowName+"正在获取任务");
		Integer number = NumberMachine.getInstance().getCommonManager().fetchServiceNumber();
		if(number!=null){
			System.out.println("第"+windowName+"号窗口正在为"+number+"普通客户服务");
			long beginTime = System.currentTimeMillis();
			int maxRand = Constants.MAX_SERVICE_TIME-Constants.MIN_SERVICE_TIME;
			long serviceTime =new Random().nextInt(maxRand)+1+Constants.MIN_SERVICE_TIME;
			try {
				Thread.sleep(serviceTime);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
			long costTime = System.currentTimeMillis()-beginTime;
			System.out.println(windowName+"为第"+number+"号"+type+"客户完成服务,耗时"+(costTime/1000));
		}else{
			System.out.println(windowName+"没有取到服务任务,休息1秒");
			try {
				Thread.sleep(1000);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
	}
}

最后创建启动类(MainClass)

package com.leo.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 vipWindow = new ServiceWindow();
		vipWindow.setType(CustomerType.VIP);
		vipWindow.start();//启动VIP服务窗口
		
		ServiceWindow expressWindow = new ServiceWindow();
		expressWindow.setType(CustomerType.EXPRESS);
		expressWindow.start();//启动快速服务窗口
		
		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().getVipManager().generateNewManager();
						System.out.println(number+"号VIP客户正在等待服务");
					}
				}, 
				0, 
				Constants.COMMON_CUSTOMER_INTERVAL_TIME*6, 
				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);
	}
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
vxworks xlnx,zynq7k-Gpio dts是指在vxWorks操作系统中,使用xlnx,zynq7k-Gpio设备树(Device Tree Source)文件进行配置的一种方式。该设备树文件中包含了与xlnx,zynq7k-Gpio相关的配置信息,用于描述和定义Gpio设备的属性和功能。通过在vxWorks bsp目录中找到xlnx_zynq7k文件夹并复制为xlnx_zynq7k_tlz7x,并在风河BSP目录下搜索所有关键字为xlnx,zynq7k-misccfg的文件,可以找到与xlnx,zynq7k-Gpio相关的代码和配置信息。根据代码分析可以看出,该驱动既支持ZYNQ7000系列,又支持MPSoc系列,使用的gpio部分是相同的IP核。因此,vxworks xlnx,zynq7k-Gpio dts是用于配置和定义ZYNQ7000系列和MPSoc系列GPIO设备的设备树文件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [实时系统vxWorks - zynq7020移植vxWorks](https://blog.csdn.net/rt201314/article/details/118742170)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [ZYQN7000系列VxWorks驱动开发:调试GPIO子系统](https://blog.csdn.net/weixin_42314225/article/details/121596418)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值