黑马程序员:银行业务调度系统学习

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

银行业务调度系统

一、项目分析

提示:画图非常有助于理解和分析项目的问题,所以一定要先画图理清楚思路。

1,三种客户类型:普通客户,快速客户,VIP客户。

客户到银行后要通过一个排号机排号,排号机上有三个选项分别是普通业务,快速业务,VIP业务。


2,银行的服务窗口开启口,工作人员会按一个按钮,喇叭就会通知哪位客户到哪个窗口,这是由一个号码管理器安排的。


3,如果VIP窗口和快速窗口空闲时,也可以临时处理普通客服的服务。

二,对象具体功能的分析

1, NumberMachine类
排号机要有三个方法分别获取三种客户类型。三种客户类型有各自的管理器,但是都由同一个排号机产生
所以排号机是单例模式

getCommonManager(),getExpressManager(),getVipManager()

package com.itcast.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(){}
	//创建静态方法来获取对象
	public static NumberMachine getInstance(){
		return instance;
	}
	//因为是静态方法调用所以要静态修饰
	private static NumberMachine instance = new NumberMachine();
}


2,   NumberManager类
定一个集合储存所以排号机产生的所有客户,

当窗口启动服务后排号机要把对应的客户分配给不同的窗口。

package com.itcast.bank;

import java.util.ArrayList;
import java.util.List;

public class NumberManager {
	private Integer lastNumber = 1;
	//储存产生的所有号码
	private List<Integer> queueNumber = new ArrayList<Integer>();
	
	public synchronized Integer generateNewManager(){
		queueNumber.add(lastNumber);
		return lastNumber++;
	}
	
	public Integer fetchServiceNumber(){
		Integer number = null;
		if(queueNumber.size()>0)
			return queueNumber.remove(0);
		return number;
	}

}


3,   ServiceWindow类:对视频中的代码做了优化但存在小问题。
定义一个start方法,表示工作人员按了按钮,向号码管理器要客户。

在定义三个不同的方法表示对不同服务。

package com.itcast.bank;

import java.util.Random;
import java.util.concurrent.Executors;

public class ServiceWindow {
	private CustomerType type = CustomerType.COMMON;
	public 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(){
				Integer number = null;
				while(true){
					switch(type){
					case COMMON:
						number = NumberMachine.getInstance().getCommonManager().fetchServiceNumber();
						service(CustomerType.COMMON,number);
						break;
					case EXPRESS:
						number = NumberMachine.getInstance().getExpressManager().fetchServiceNumber();
						service(CustomerType.EXPRESS,number);
						break;
					case VIP:
						number = NumberMachine.getInstance().getVipManager().fetchServiceNumber();
						service(CustomerType.VIP,number);
						break;
					}
				}
			}
		});
	}
	//建立窗口服务的方法。
	private void service(CustomerType type,Integer number) {
		String windowName = "第" + windowId + "号【"+type+"】 窗口";
		System.out.println(windowName + "正在提供服务");
		if(number!=null){
			System.out.println(windowName + "正在为第(" + number + ")位"+ "【"+type+"】客户服务!");
			long beginTime = System.currentTimeMillis();
			int maxRand = Constants.MAX_SERVICE_TIME - Constants.MIN_SERVICE_TIME;
			long serverTime = new Random().nextInt(maxRand) + 1 + Constants.MIN_SERVICE_TIME;
			
			try {
				Thread.sleep(serverTime);
			} catch (Exception 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 (Exception e) {
				e.printStackTrace();
			}
		}
	}
}


4,  CustomerType类

用枚举定义三种类型的客户

package com.itcast.bank;

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

Constant 类

package com.itcast.bank;

public class Constants {
	public static int MAX_SERVICE_TIME = 10000;
	public static int MIN_SERVICE_TIME = 1000;

}

Main类

package com.itcast.bank;

import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

public class Main {

	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();

		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, 1, TimeUnit.SECONDS);
		
		Executors.newScheduledThreadPool(1).scheduleAtFixedRate(
				new Runnable(){
					public void run(){
						Integer number = NumberMachine.getInstance().getExpressManager().generateNewManager();
						System.out.println(number + "号快速客户等待服务");						
					}
				}, 0, 6, TimeUnit.SECONDS);

		Executors.newScheduledThreadPool(1).scheduleAtFixedRate(
				new Runnable(){
					public void run(){
						Integer number = NumberMachine.getInstance().getVipManager().generateNewManager();
						System.out.println(number + "号VIP客户等待服务");						
					}
				}, 0, 3, TimeUnit.SECONDS);

	}

}


---------------------- android培训java培训、期待与您交流! ----------------------详细请查看: http://edu.csdn.net/heima
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
学习PBS作业调度系统可以按照以下步骤进行: 1. 了解PBS的基本概念:首先,你需要了解PBS(Portable Batch System)的基本概念和工作原理。了解PBS的特点、作业调度流程、资源管理等方面的知识。 2. 学习PBS的命令和使用方法:掌握PBS的命令和使用方法是使用PBS作业调度系统的关键。学习如何提交作业、查询作业状态、取消作业等常用命令。 3. 配置和管理PBS集群:学习如何配置和管理PBS集群,包括节点配置、队列管理、资源限制等。了解如何设置节点属性和资源限制,以便更好地管理和调度作业。 4. 了解PBS的策略和调度算法:学习PBS的策略和调度算法可以帮助你更好地理解作业调度的原理和机制。了解如何设置作业优先级、调整作业队列等,以及如何根据集群资源状况进行调度。 5. 探索高级功能和扩展:进一步学习PBS的高级功能和扩展,如作业依赖关系、作业数组、资源共享等。这些功能可以帮助你更好地管理和控制集群中的计算任务。 6. 实践和应用:通过实践和应用,将学到的知识应用到实际的工作中。提交作业,观察作业的调度和执行情况,分析和优化作业性能。 7. 深入学习其他相关技术:PBS作业调度系统通常与其他技术和工具一起使用,如集群管理工具、资源管理器等。深入学习这些相关技术可以帮助你更好地理解和应用PBS作业调度系统。 通过以上步骤,你可以逐步掌握PBS作业调度系统的基本原理和使用方法,并在实践中不断提高你的技能。同时,可以参考官方文档、教程和在线资源来获取更多的帮助和指导。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值