OO电梯调度
告别了三次奇妙无比的求导作业之后,我们就开始搭建一部自己的电梯了。相信我们不同同学的电梯运行方式肯定各具特色吧,但值得肯定的是,在艰苦的走完了三次电梯逐步改进的作业之后,我们的电梯在正常情况下应该是可以运作了~所以当我们一起坐电梯,相信我们的电梯应该是不会接不到人、把人最后关在里面、莫名其妙的就把人给丢了以及把人送到+
或者是-
的啦。下面是我对这三次作业的总结与分析~
在三次作业中我都是用的三个线程。一个是main线程,主要负责构造并start另外两个线程,构建调度器对象;另外两个是Request与Elerun线程,顾名思义,一个用来得到请求并将请求put到调度器,另一个用来模拟电梯运行。调度器类命名为Control。
FAFS电梯调度
对于刚刚接触多线程的我来说,要实现一部相对智能的电梯几乎是不可能的,更不要说是多部电梯了。应该也是出于对同学们情况的考虑吧,第一次作业只是要求我们实现VIP(傻瓜)级别的电梯调度。即在任一时刻每当有一个用户给电梯发送了一个请求,那么调度器就将该请求传递给电梯,电梯在运行路径上不用去接其他的人,只把接到这个请求当作目标,来一次执行完各个请求。
设计思路:
因为这次作业不要求具体的各个请求之间的调度,所以我甚至没有在调度器里面构建一个链表。在Request得到一个输入之后便立马put给调度器,如果此时调度器之前要put的请求还没有被电梯get到,那么就先让put方法等待,直到电梯get完前一个请求之后再将这一个put进去。同样,在电梯get的时候,如果此时没有请求则调度器便让当前电梯的线程wait,直到put进一个请求被notify了之后才继续运行。最后在Request得到程序输入结束的指示后,会给调度器传入一个自定义好了的请求,而当电梯读到那个请求之后,便会直接结束运行。
下面是第一次作业的结构度量:
类图:
复杂度分析:


时序图:

ALS电梯调度
在FAFS电梯的基础上,这次调度要求电梯在运行过程中可以捎带着人以减少电梯的总运行时间,同时增加了底下层,具体原因不清楚为什么,好像是为了避免出现固定化楼层分析的情况?不过在这次编程中值得注意的一点是从底下-1层到1层电梯只是运行了1层,而不是单纯的减法就能够满足的了。
设计思路:
在Request线程方面,与第一次差别不大。唯一的区别就是在put的时候会直接put到调度器里面一个已经构建好的请求链表(比较习惯用ArrayList)里,这样Request每读到一个输入则会避免了等待而直接压入同时notifyAll一次主要来唤醒电梯的Elerun线程。
在电梯进行get初步读入请求时,如果此时ArrayList链表为空,则一直wait,直到Request线程重新唤醒该线程后再继续运行。在电梯运行时,我设计思路是电梯get时只get到第一个人的位置作为主请求,同时电梯向第一个人的方向运行,在每一层判断一次请求链表中是否有与电梯运行方向相同的人或者事要下电梯的人,如果有则在该层停靠完成相应的in或者out的过程,在in的时候每进入一个人则删除请求链表里的该请求。直到电梯将初步get到的请求运行完之后再重新从链表里得到一个新的主请求。
不足之处:
虽然这样写可以比较稳定的实现电梯在运行过程中执行捎带人的动作,而且也能知道电梯此时的运行情况及运行状态。但是有一个比较重要的点没有考虑到,就是假如有三个人同时分别在13、14、15层按了向下的按钮,那么此时电梯就会从一层上来逐个的送回三个人,那么在这种情况下就和FAFS电梯一样了,这是一个在设计层面上没有想到的情况,拉低了自己的性能分。而我在后来改进的时候只需要判断是否有比当前请求更适合作为主请求的请求,就可以初步的改进这个问题。
下面是我的第二次作业的度量分析:
类图:
复杂度:
时序图:
SS电梯调度
第三次作业在第二次的基础上,增加成了三部电梯,并且规定了电梯所能到达的楼层各不相同,运行速度不同,容量不同等限制因素。要求尽可能的实现优化调度以在比较少的时间内执行完所有的请求。我在第二次作业的基础上,对Elerun与调度器进行了修改。
不同于第二次作业,我是在调度器里买面改成了三个链表存储对应的请求。每个电梯在每次改变状态时便实时通知调度器,在Request读取到一个请求之后便调用调度器的put函数,调度器根据此时各个电梯的运行状态来将此请求压入制定的链表。下面是部分内容的更详细的介绍。
首先介绍我实现的调度器是怎样将读到的请求尽量合理的压入不同链表的。如图所示,我在调度器里面用0代表A电梯,用1代表B电梯,2代表C电梯,这个二维数组表示不同

的电梯所能到达的楼层,能到达则为1,不能则为0。这样在判断电梯能否到达楼层时只需判断对应的值是否为1就可以了。那么在调度器得到一个请求之后,按照下面的步骤筛选应该压入的链表。

由于时间限制和个人能力不足的原因吧,我没有完成只把请求压到一个指定的链表中去的假想,在最后一步筛选时间最短时的筛选条件比较苛刻,如果没有满足的电梯,则就把该请求压入到满足前一个请求的电梯的链表里。
还有一点要提的是换乘时的判断。当没有电梯可以直达时,我先筛选出能在此层停靠的电梯,然后针对每一个电梯,筛选该电梯可以到达的最近的楼层floor,且有电梯可以在该floor直达目的地,那么我以此楼层作为中转,修改之前的请求。对应每一个电梯,当拆分请求完成后,压入对应的请求链表,完成拆分。
下面是我的第三次作业的度量分析:
类图:

复杂度:



总结与感想
这三次作业在强测和互测中都没有被
OO电梯调度的更多相关文章
- OO第二次博客作业——电梯调度
OO第二次博客作业——电梯调度 前言 最近三周,OO课程进入多线程学习阶段,主要通过三次电梯调度作业来学习.从单部电梯的傻瓜式调度到有性能要求的调度到多部电梯的调度,难度逐渐提升,对同学们的要求逐渐变 ...
- OO第二单元总结(多线程的电梯调度)
经过第一单元作业的训练,在做第二单元的作业的时候,要更加的有条理.但是第二次作业多线程的运行,带来了更多的运行的不确定性.呈现出来就是程序会出现由于线程安全问题带来的不可复现的bug.本单元的作业也让 ...
- oo第二次博客-三次电梯调度的总结与反思
本单元从电梯调度相关问题层层深入,带领我们学习并运用了了多线程相关的知识. 三次电梯调度依次为单电梯单容量.单电梯可携带.多电梯可携带. 一.我的设计 在第一次作业中,使用了最简单的FIFO调度方法. ...
- 电梯调度编写(oo-java编程)
第二单元的问题是写一个关于电梯调度的程序. 需要模拟一个多线程实时电梯系统,从标准输入中输入请求信息,程序进行接收和处理,模拟电梯运行,将必要的运行信息通过输出接口进行输出. 主要锻炼学生的多线程程序 ...
- 学会拒绝,是一种智慧——OO电梯章节优化框架的思考
在本章的三次作业里,每次作业我都有一个主题,分别是:托盘型共享数据.单步电梯运行优化.多部电梯运行优化,因而电梯优化实际是第二.三次作业.虽然后两次作业从性能分上看做得还不错,但阅读其他大佬博客,我深 ...
- 【软件工程】电梯调度的初步实现 李亚文&&郭莉莉
一.开门见山,代码粘 using System; using System.Collections.Generic; using System.Data; using System.Drawing; ...
- 电梯调度--c++--软件工程
一.设计思路 (1)将乘客要去的楼层数存起来. (2)假设yi为乘客要爬楼层数之和,yi=n1*|(n1-ni)|+n2*|(n2-ni)|+..+n18*|(n18-ni)| (3)比较y1到y18 ...
- 电梯调度系统(界面由C图形库编绘)
1.编程题目 电梯调度系统 2.结对编程组员 黄冠译,刘畅 3.编程语言 C语言图形库 4题目要求 编写人员:刘畅,黄冠译 代码如下: # include <stdio.h> # incl ...
- PairProject 电梯调度 【附加题】
[附加题] 改进电梯调度的interface 设计, 让它更好地反映现实, 更能让学生练习算法, 更好地实现信息隐藏和信息共享. 目前的设计有什么缺点, 你会如何改进它? 1.之前判断电梯是否闲置的函 ...
随机推荐
- 黄聪:原生js的音频播放器,兼容pc端和移动端(原创)
更新时间:2018/9/3 下午1:32:54 更新说明:添加音乐的loop设置和ended事件监听 loop为ture的时候不执行ended事件 1 2 3 4 5 6 7 8 9 10 11 12 ...
- Centos 7 64位 minimal 最小化安装的系统中静默安装oracle 11g r2
1:安装好centos 7 操作系统: 虚拟机安装centos 7,在vmware中一步步来就可以成功. 2:安装vim 最小化安装的系统只有vi编辑器,这里装一下vim,个人习惯,可以不安装, 那么 ...
- js无间隙向上滚动
一.优点:div可以load:缺点:滚动的时候有点娘,磨磨唧唧,不够干脆爽快 html <div id="my_msg" class="my-msg bg-whit ...
- Unity 三角函数 向量 运算
其实三维的和二维的基本差不多,一样的运算方式,unity已经把所有的方法都封装起来,主要是理解,能理解了就直接调用了 三角函数 知识点:三角函数基础正玄余玄.三角函数曲线.弧度制和角度制.弧度制和角度 ...
- 序列化模块_pickle
序列化: 把不能够直接存储的数据变成字节流(bytes)保存在文件, 进行持久化存储 反序列化: 任何数据都可以转成字节流(bytes)进行存储: 1. dumps 把任意对象序列化 li = [1, ...
- 机器学习笔记之二-win10+cuda9.1+CUDNN7+Anaconda3+VS2017+tensorflow1.5+opencv3.4
[Tensorflow]环境搭建vs2017+win10+py3.6+cuda9.1+cudnn7+tf1.5 一.安装cuda 9.1+VS2017 一路下一步即可,环境变量cuda会自动配好 ...
- gmer ver2.1.19357
gmer是一款来自 波兰 的多功能安全监控分析程序.它可以结束除了System和System Idle Process以外几乎所有的进程,还可以查看被隐藏的进程,服务以及驱动(以红色的方式显示此进程. ...
- jail-break-rule
switchOmega plugin for firefox and chrome https://raw.githubusercontent.com/gfwlist/gfwlist/master/g ...
- 关于RandomAccessFile一个坑!!!!
最近正好遇到了使用RandomAccessFile做断点下载的情况,被一个问题坑了好多次 本来的代码: RandomAccessFile randomAccessFile = new RandomAc ...
- 三、CSS样式——文本
CSS文本 概念:CSS文本属性可定义文本外观 通过文本属性,可以改变文本的颜色.字符间距.对齐文本.装饰文本.对文本缩进 属性 描述 color 文本颜色 direction 文本方向 line-h ...




