Servlet+AJAX实现的模拟电梯调度

需求产生:

  大三下学期天天在学校的同一栋教学楼上课,每天要等四次电梯,有次等电梯无聊了,就想到电梯的运行逻辑该如何用程序来表达呢?

问题描述:

  大学的那栋楼有21层,不过在页面中画21层有点密,所以只画了9层;

  同时有三座电梯等待调度;

  按钮分为楼层按钮和电梯内按钮,电梯内按钮有楼层数字和关门按钮;

  运行的要求:

    1.电梯空闲时,电梯内按钮被点击,对应按钮被点亮,需要按关门键自动运行到最近的楼层;

    2.电梯正在运行过程中,电梯内按钮被点击,如果离电梯更近,需要自动更改电梯目的停靠楼层为新添加的请求楼层,否则电梯还是到达原定楼层;

    3.与电梯运行状态相反的电梯内按钮将不会被响应,比如从四楼向上运行的电梯,1、2、3楼按钮无法点击;

    4.楼层按钮请求因为三个电梯共享按钮请求,所以应该设计一个合理的调度选择;

      ①最优先选择这样的电梯:正在前往本楼层的电梯,如5楼向上的按钮被点击了,电梯B要从3楼到9楼,那么优先选择电梯B,且会先停靠5楼;

      ②其次选择这样的电梯:空闲状态的电梯,如果没有符合①中条件的电梯,那么随机选择一个空闲状态的电梯(这里可以优化的,选择最近的电梯)运行到当前楼层接人;

      ③如果没有以上两种条件的电梯存在,那么保持请求状态,直到以上两种条件之一出现,如1楼的向上请求,但电梯ABC都在从2楼向上运行,那么选择最                           先完成任务停止的电梯到1楼接人。

    5.电梯到达某一层,电梯内亮着的按钮被熄灭,楼层按钮有两种情况:

      ①当前电梯到达这一层楼之后没有下一层楼的目标了,更改状态为空闲,向上和向下的按钮都熄灭(此条是因为4-②中如果向下请求,但电梯从下面运行上来时,熄灭的应该是向下的按钮);

      ②当前电梯有继续运行的下一层目标,只熄灭与当前运行方向相同的楼层按钮。

界面:

  

包结构:

1.po层:

  FutureFloor作为实体类,使用五个TreeSet保存按钮请求数据(因为TreeSet 有序,唯一),这五个TreeSet分别保存,楼层上升请求、楼层下降请求、三个电梯内按钮请求;

  FutureFloorFactory,实体类的工厂类;

2.service层

  Service:封装一些方法;

3.servlet:

  按顺序分别为:

  电梯停靠楼层时触发的响应;

  电梯开始运行时触发的响应;

  电梯内关闭按钮被点击时触发的响应;

  设置编码的过滤器;

  电梯内按钮响应;

  楼层按钮响应;

  向前端页面返回电梯当前状态;

缺陷:

  其实保存电梯状态只在前端保存,然后传递就可以了,后台保存需要每次操作更改状态,容易造成纰漏,且没有页面保存的实时性;

源码:

https://files.cnblogs.com/files/liumaowu/elevator.zip

    

原文地址:https://www.cnblogs.com/liumaowu/p/9258943.html

时间: 2024-11-08 16:08:23

Servlet+AJAX实现的模拟电梯调度的相关文章

软件工程作业之电梯调度

问题描述: 某大楼共有20层,现安装4个电梯参数如下: 1号电梯 全楼层 最大负载800kg 2号电梯 单数层 最大负载800kg 3号电梯 双数层 最大负载1600kg 4号电梯 全楼层 最大负载2000kg 分析: 4个电梯是相互独立工作的,那么分为4个相互独立的调度模块.1号电梯与4号电梯均服务于全楼层且仅有最大负载不同,而2号和3号电梯 服务模式类似.那么1.4号电梯调度模块可合并为一个.同样地,2.3号模块也可以合并.电梯调度的核心功能是接受不同楼层用户的请求并相应,而同一部电梯某时刻

电梯调度 结对开发项目

一:项目名称: 电梯调度模拟程序 二:项目参与人员: 周其范 胡宝月 三:项目开发语言和工具: Java语言和eclipse,涉及内容:面向对象技术.基于Swing的图形化用户界面.多线程启动和休眠 四:问题陈述: 1.电梯要正常运行,能响应内部.外部按钮 2.要怎样选择哪部电梯电梯,使乘坐者和电梯的距离更近,已达到更省电.更快.更经济. 3.同一部电梯可以响应多位乘客的请求 五:任务需求: 1.要模拟一栋6层楼中两部电梯的调度,模拟乘坐电梯的过程. 2.乘坐者在最低层楼:只能乘坐电梯上楼,在电

电梯调度设计

题目:电梯调度 设计:郭庆樑,张科 一.设计思路 1.问题描述: 说明:电梯调度算法的基本原则就是如果在电梯运行方向上有人要使用电梯则继续往那个方向运动,如果电梯中的人还没有到达目的地则继续向原方向运动.具体而言,如果电梯现在朝上运动, *  如果当前楼层的上方和下方都有请求,则先响应所有上方的请求,然后才向下响应下方的请求:如果电梯向下运动,则刚好相反. * 设计要求:每一对学生将设计一套接口和类定义这样一种算法提供者可以提供他/她实现“电梯调度程序”. 避免出现 “公共汽车”最坏情况的算法.

结对编程-电梯调度

这次编程和前几次不同,这次是结对编程,就是一个人编码,一个人负责审查,两个人编程过程中要交换角色,不能全程一个人编程而另一个人只审查.我的结对队员是张心语.他是一个活泼开朗的大男孩,也是一个文艺小青年.可能是考研的原因,或者是其它什么原因,这次结对效果不是太理想,我多次找过他但他说有事,所以整个结对编程基本就是我一人在整,就连最后拍的结对照片也是为了满足老师的要求.虽然没有达到老师期望的结果,但我依然收获很大.从一开始看的题目的无从下手,到与人交流,再到最后编码,成长了很多,编程能力也得到了进一

结对项目——电梯调度之界面粗略规划与设计

在程序运行时要显示一个菜单界面,用于用户的一些操作.分为进入菜单,总控台菜单,以及退出. 在进入菜单里我们主要就是设计模拟电梯运动. 首先先分析下现实中的电梯: 1.在外界每一楼层都能够有选择上下的按钮(最低一层只有上,最高一层只有下) 2.选择方向与电梯的运行方向不同时,只有当电梯状态变成静止时才响应 3.电梯内部有能选择楼层的按钮 4.电梯有限载 设计初想: 1.进入菜单: 在每一层的上下按钮可以直接用button控件,显示的文字是:楼层+上/下:然后通过获取控件上的文本信息的第一个字符来确

结对开发--电梯调度报告

“电梯调度”需求分析 一.项目背景 试想一下,石家庄铁道大学基础教学楼的电梯配置如下:大厦有18层, 4部电梯,很多乘客使用这些电梯的日常(旅客重量:平均70公斤最大120公斤,最小45公斤).其他常量数据:电梯速度,开/关门时间,乘客的时间要在/走出电梯.可以对这些合理的假设. 二.数据分析 我们随机选择了一天去现场调查基础教学楼电梯的使用情况,列表如下: 电梯名称 停靠层数 乘客限制 重量限制/kg 电梯开关时间/s 乘客进出电梯时间/s 电梯1 8-18层(双层) 15人 1150 4s

对于电梯调度的想法

电梯调度 现有一新建办公大厦,共有21层,共有四部电梯,所有电梯基本参数如下表所示: 电梯编号 可服务楼层 最大乘客数量 最大载重量 1 全部楼层 10 800 kg 2 单层 10 800 kg 3 双层 20 1600 kg 4 全部楼层 20 2000 kg 其使用规定如下: 1.楼层号为0~20,其中0号为地下一层: 2.有楼层限制的电梯不在响应楼层停靠,如单双层: 3.所有电梯采用统一按钮控制 请根据上述要求设计并实现一个电梯控制程序,如果有图形显示就更好了. 对于这个问题我有以下想法

软件工程课堂作业(七)续——电梯调度之整体设计

一.题目要求: 1.可以获得电梯和乘客所在楼层: 2.可以根据乘客的需求到达想到达的楼层. 二.设计思路: 1.通过用户输入可以获取乘客和电梯所在楼层: 2.通过循环,输出电梯向上/向下走的过程. 三.源代码: 1 // 电梯调度——胡亚宝 2 // 3 4 #include "stdafx.h" 5 #include<iostream> 6 using namespace std; 7 8 9 int _tmain() 10 { 11 int a,b,c,m,i; 12

课堂练习--电梯调度

一.题目要求 •石家庄铁道大学基础大楼一共有四部电梯,每层都有人上下,电梯在每层都停.信1201-1班的XXX东觉得在每层都停觉得不耐烦. •由于楼层不太高,在上下课高峰期时时,电梯从一层上行,但只允许停在某一楼层.在一楼时,每个乘客选择自己的目的层,电梯则自动计算出应停的楼层. •问电梯停在那一楼层,能够保证这次乘坐电梯的所有乘客爬楼梯的层数之和最少. 二.设计思想 这次的电梯的设计题目一开始我其实想明白了,但是老师后来讲了半天结果又说迷糊了...所以今天做作业之前看了一下同学们的设计思想,发