oo第二单元博客总结

在第一单元求导结束后,迎来了第二单元的多线程电梯的问题,在本单元前两次作业中个人主要应用两个线程,采用“生产者-消费者”模式和共享数据变量的方式解决问题。在第三次作业中加入多个电梯线程以后,沿用之前的模式,但是在控制线程的地方进行了部分相应的修改保证任务的完成。

第一次作业—傻瓜电梯

第一次作业是没有任何调度算法的傻瓜电梯,生产者生产请求,将请求加入存储的仓库队列。消费者消费请求,循环从仓库中取出请求,取出一个请求即运送他,直至运送完毕后,再进行循环。

下面是第一次作业的类图,个人感觉还是比较清晰的。

此次作业中由于几乎没有调度要求所以没有查找到bug。

第二次作业—als调度电梯

第二次作业中加入了一些新的调度要求,要求在运送请求的过程中进行捎带,以减少电梯的运行时间。自己的设计主要是在第一次作业的基础上,在电梯运送主请求的过程中,在每一楼层与仓库队列进行交互,查询是否有可以进行捎带的请求,是否可以有从电梯中出去的请求。(本人比较菜,没有进行过多的算法优化,所以此次的作业在保证了简单的正确性的情况下,收获的性能分却很低。

此次自己设计的调度比较简单,所以没有被查找到bug。因为没有自己的测评机,所以在测评中主要用了暴力输入的方式,导致效率非常低下,并且也没有找到别人的bug。

第三次作业—多线程智能电梯

第三次作业加入了更多更加复杂的要求,电梯能够到达的楼层不同,电梯所能够承载的人数不同,这两点是在本人设计电梯的过程中最主要的两点要求,也是在本次作业中本人踩坑的地方。自己的设计主要采用了暴力分配的方法,仓库队列中每进入一个请求,对于请求先进行拆分,如果可以直达,则不进行多余处理;如果不能直达,则一定可以通过一次换乘到达终点,将请求处理完毕后加入仓库队列。电梯线程的设计沿用第二次als调度电梯的设计,在能够到达的楼层与仓库队列进行交互。

第三次作业中个人遇到很大的困难是如何判断电梯线程的停止。由于出现了换乘,所以前两次作业中通过判断输入停止和仓库队列为空的方法不再适用,最终的解决方法是在仓库队列中加入一个人员队列存储所有的请求,只有请求到达最终的终点后才能够从队列中清除掉,将这个人员kill掉,最终的电梯线程停止的判断条件变为输入停止和人员队列为空。

此次电梯的设计出现一个非常愚蠢的bug,就是在电梯判断捎带的过程中,没有判断在该楼层能否停靠,导致了严重的bug。

这是画出的这三次作业的简单的处理图,在第三次中加入了下方的处理类,先将请求进行处理后再进行其他的处理。

心得和体会

这三次多线程作业主要考察的难点就是在线程安全的设计和调度运行的优化等方面,线程安全我主要是采用synchronized同步机制,来锁住输入线程和电梯线程的对于共享变量的操作方法;如果仓库队列为空,则使用wait()和notifyAll()来释放锁和唤醒线程。调度运行的优化方面其实我没有做很多工作,没有成功地加入观察者模式,也没有加入完整的scanner算法,只是进行了简单的捎带简化,因为本身之前对于多线程了解不清晰,在作业中更多的设计主要是想确保线程的安全性。

其实在此次第三次作业中踩了很大的坑,现在回过头来反思,其实很大的原因是课下自己测试的不足,代码测试的重要性是绝对不容许被忽视的。

oo第二单元作业总结的更多相关文章

  1. 【OO学习】OO第二单元作业总结

    OO第二单元作业总结 在第二单元作业中,我们通过多线程的手段实现了电梯调度,前两次作业是单电梯调度,第三次作业是多电梯调度.这个单元中的性能分要求是完成所有请求的时间最短,因此在简单实现电梯调度的基础 ...

  2. 电梯也能无为而治——oo第二单元作业总结

    oo第二单元作业总结 一.设计策略与质量分析 第一次作业 设计策略 在第一次作业之前,我首先确定了生产者--消费者模式的大体架构,即由输入线程(可与主线程合并)充当生产者,电梯线程充当消费者,二者不直 ...

  3. OO第二单元作业总结【自我反思与审视】

    第二单元作业的完成史,就是一部心酸的血泪史…… 多线程的出现为我(们)打开一片广阔的天地,我也在这方天地摸爬滚打,不断成长!如果说第一单元之前还对Java语法有所了解的话,那么这单元学习多线程则完全是 ...

  4. OO第二单元作业小结

    前言 转眼已是第九周,第二单元的电梯系列作业已经结束,终于体验了一番多线程电梯之旅. 第一次作业是单电梯的傻瓜调度,虽然是第一次写多线程,但在课程PPT的指引下,写起来还是非常容易:第二次作业是单电梯 ...

  5. 电梯模拟系统——BUAA OO第二单元作业总结

    需求分析 官方需求 本次作业需要模拟一个多线程实时多电梯系统,从标准输入中输入请求信息,程序进行接收和处理,模拟电梯运行,将必要的运行信息通过输出接口进行输出. 本次作业电梯系统具有的功能为:上下行, ...

  6. OO第二单元作业分析

    前言 这一单元关于线程安全的作业结束了,在助教提供的接口的帮助以及老师提供的设计模型的指导下,这三次作业还是相对轻松地完成了,中间也没有出现什么bug,可能就是因为简单的逻辑不容易出错吧,可惜两次都由 ...

  7. 你电梯没了—OO第二单元作业思考

    写在前面 这三次电梯调度作业,主要是学习多线程并行操作,对于各个线程的时间轴的把握,互相的配合与影响,通过使用锁来解决访问冲突等方面. 个人在学会Thread相关操作之外,写出来一些奇怪结构的诡异操作 ...

  8. 北航OO第二单元作业总结(2.1~2.3)

    在经过第一单元初步认识面向对象编程思想后,本蒟蒻开始了第二单元--多线程部分的学习.本单元的作业是构造符合条件的"目的选层电梯"模型,自行设计调度算法,进行合理调度,完成所有乘客的 ...

  9. OO第二单元作业——魔鬼电梯

    简介 本单元作业分为三次 第一次作业:第一次作业要实现单部简单电梯,停靠所有楼层,无载客容量,性能分考量电梯运行时间. 第二次作业: 第二次作业实现多部电梯,电梯数量由初始化设定,每部电梯都停靠所有楼 ...

随机推荐

  1. C# - 代码重构

    隐藏更多 只暴露集合中供人使用的单一功能,将关于集合的更多功能隐藏掉. 旧版本 public class Animal{    private List<string> LanguageL ...

  2. php 默认保几位小数,末尾为0去掉

    计算保留几位小数,末位为0舍去 // 计算 默认保留1位小数 protected function getSprintf($value,$count,$digit = 1) { $num = 0; i ...

  3. sed 正则 ! 取反

    !符号表示取反,x,y!表示匹配不在x和y行号范围内的行,利用sed命令用于的阿银不在2-7之间的行 [111 sed]$ cat input [111 sed]$ sed -n '2,7!p' in ...

  4. 帆软报表(finereport)图表——扇形图/等弧度的玫瑰图

    扇形图/等弧度的玫瑰图,展示的是展示数据所占的比例,需要所有数据的和加起来为1. 下面利用一个实例说明玫瑰图的用法和设置起始角度和终止角度,操作如下: 1.配置一个内置数据集 新增一个等弧度的玫瑰图模 ...

  5. mybatis基础知识

    一.什么是Mybatis 这里借用官网的一句话介绍什么是mybatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC ...

  6. jquery 第三章

    1.回顾$(document).ready(function(){    })$(function(){    }) ID选择器.类选择器.元素选择器层次选择器:空格(上文下:tr td{})属性过滤 ...

  7. Three teachers who make differences in my life

    人生路漫漫,从小到大,经历过九年义务教育的我们也受到过很多老师的熏陶,而已经进入大学的我也会回想起那些给我带来别样意义的老师们. 亲爱的老李-老李是我初中的班主任,也是我的历史老师.依稀记得上他的课会 ...

  8. CSS之分组选择器和嵌套选择器

    分组选择器, 将一个样式应用于多个类,或者标签啥的 每个选择器用逗号隔开 <!DOCTYPE html> <html> <head> <meta charse ...

  9. docker /var/lib/docker/aufs/mnt 目录满了,全是垃圾数据

    #!/bin/sh echo "==================== start clean docker containers logs ======================= ...

  10. PHP游戏概率方法

    <?php function createRandomKey($randArr, $rateKey){ $total = 0; $chooseArr = array(); $pow = 0; / ...