oo第二单元的自白
电梯第一次作业
第一次电梯较为简单,主要目的在于初步接触多线程,可以实现一些简单的操作。
在本次作业中,为了更好的了解多线程,我也阅读了一些代码,并据此仿写完成了第一次作业。
根据生产者和消费者的模式,读入线程即为生产者,电梯与调度器一起为消费者。仓库的容量为1,故两线程相互进行等待(这主要是没有真正的理解其原理,而迫不得已的仿写)。
电梯第二次作业
第二次作业的构造大体与前相同,不过没有开新的线程进行读入处理,而是直接在main方法中进行。
实际调度类似于scanner,但却又比其差了一些。
(其实,我是按照指导书提供的想法进行实现。但我的理解和别人不大一样,当电梯中有人时,即将电梯中第一个进入的人的请求作为主请求,电梯无人,将第一个等待的人的请求作为主请求,而一旦有人进出电梯,立即进行一次主请求的刷新。)
电梯第三次作业
本次作业最重要的一个问题就是如何进行电梯间的通信(多电梯完成一个request时)和有效的利用电梯资源(优化)。
在此,我进行的处理是,将scheduler作为一个共享的对象,其内的成员变量为三个list,分别对应于三部电梯。
将需要多个电梯完成的任务进行拆分,在人为到达时,将list中的有效位置为false,当人到达中转站时,置为true。
三次作业中的问题与一些想法
第一次作业作为入门,几乎完全照抄生产者与消费者模式。
第二次作业,有了第一次的基础后,又理解了一些内容,进行了改进。
1.将读入方法归入到main中
2.仓库容量从1改为无穷大,即删除了读入方法中的wait,由接口提供的阻塞方法来完成wait。
3.第一次作业直接使用synchronized包装run方法,第二次将新写的共享对象类中的方法进行synchronized包装,减小了包装的大小。
第三次作业,实际上大体思路延续第二次,但又有一些问题。
1.在自己课下debug的过程中,发现了电梯停不下来的情况,经过反反复复的debug,发现是关于暂停信息的设置出现了问题。在读入为空时,将唤醒电梯,随后设置结束信号为真。(这实际上就是和第二次作业一模一样的,所以第二次作业存在着问题,只是没有被发现,或者说出现的概率极低)将其更改为先设置结束信号为真,再唤醒电梯即可。
2.关于强测中的炸点问题,出现原因是存在隐式小轮询,第二部电梯会在中转楼层反复判断该请求id是否到达,添加了wait和notify即可解决。
3.关于run方法过长,应该考虑将run中内容打包为方法,在run中直接进行调用即可。
4.关于优化,最初的设想中,将所有可以达成该目的的调度方法分别对用存入到三台电梯各自的请求队列里,但实际情况极为复杂,例如3到-2,包含了C转A和C转B两种情况,在中弱测中,我的调度会将该id进行两次的入电梯C,想要继续进行修改过于复杂,而且即便进行修改,又不知是否会有其他的错误出现,在时间不足的情况下,只好修改为每个id仅有唯一的乘电梯方式。同时,这也告诉了我,在写代码前,一定要有严格的设计,可以减少时间。
oo第二单元的自白的更多相关文章
- oo第二单元作业总结
oo第二单元博客总结 在第一单元求导结束后,迎来了第二单元的多线程电梯的问题,在本单元前两次作业中个人主要应用两个线程,采用“生产者-消费者”模式和共享数据变量的方式解决问题.在第三次作业中加入多个电 ...
- OO第二单元优化博客
OO第二单元优化博客 第五次作业没有性能分,但是,我在这一单元的宗旨就是写一个日常生活中 最常见的那种电梯,所以第五次我没有写傻瓜电梯,而是直接写了个\(look\),和第六次基本相同. 总计一下lo ...
- 【OO学习】OO第二单元作业总结
OO第二单元作业总结 在第二单元作业中,我们通过多线程的手段实现了电梯调度,前两次作业是单电梯调度,第三次作业是多电梯调度.这个单元中的性能分要求是完成所有请求的时间最短,因此在简单实现电梯调度的基础 ...
- OO第二单元小结
OO第二单元小结 一.三次作业代码分析. 1.第一次作业 第一次作业是单部电梯的傻瓜调度,由于其过分傻瓜,所以第一次作业我只有两个类,一个main,一个电梯,main类负责不断从输入流中读取命令,如果 ...
- OO第二单元多线程电梯总结
OO第二单元多线程电梯总结 第一次作业 设计思路 Input为输入线程,负责不断读取请求并将读到的请求放入调度器中. Dispatcher为调度器,是Input线程和Elevator线程的共享对象,采 ...
- 电梯也能无为而治——oo第二单元作业总结
oo第二单元作业总结 一.设计策略与质量分析 第一次作业 设计策略 在第一次作业之前,我首先确定了生产者--消费者模式的大体架构,即由输入线程(可与主线程合并)充当生产者,电梯线程充当消费者,二者不直 ...
- 2020北航OO第二单元总结
2020北航OO第二单元总结 前言 本单元考察基于多线程的电梯调度问题,成功让我从一个多线程小白到了基本掌握了使用锁来控制线程安全的能力,收获颇多(充分体验了迷茫地de一个又一个死锁bug的痛苦). ...
- OO第二单元——多线程(电梯)
OO第二单元--多线程(电梯) 综述 第二单元的三次联系作业都写电梯,要求逐步提高,对于多线程的掌握也进一步加深.本次作业全部都给出了输入输出文件,也就避免了正则表达式判断输入输出是否合法的问题. 第 ...
- OO第二单元作业总结【自我反思与审视】
第二单元作业的完成史,就是一部心酸的血泪史…… 多线程的出现为我(们)打开一片广阔的天地,我也在这方天地摸爬滚打,不断成长!如果说第一单元之前还对Java语法有所了解的话,那么这单元学习多线程则完全是 ...
随机推荐
- create-react-app创建项目并用git上传至GitHub及展示预览效果
1.在本地中创建一个项目所在的文件夹 2.npm -g create-react-app 3.在此文件夹下 create-react-app react-demo (项目名) 4.cd react-d ...
- JSON.parse()和eval()的区别
json格式非常受欢迎,而解析json的方式通常用JSON.parse()但是eval()方法也可以解析,这两者之间有什么区别呢? JSON.parse()之可以解析json格式的数据,并且会对要解析 ...
- java pdf转word 高效不失真
将java工程导成jar包 使用 bat 执行 jar 包. --------------------------------------------------------------------- ...
- python networkx:绘制网络图
1.简单使用 import networkx as nx import matplotlib.pyplot as plt G = nx.Graph() G.add_edge(1,2) nx.draw_ ...
- MySQL语法大全_自己整理的学习笔记(MySQL语句 整理二)
select * from emp; #注释 #--------------------------- #----命令行连接MySql--------- #启动mysql服务器 net start m ...
- Mybatis中的CDATA标签
术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data). 在 XML 元素中,"<" 和 "&& ...
- [C#.Net]Window服务调用外部程序
最近遇到要做回传服务内增加开关,可以自定义运行一些脚本已方便收集PC状态,发现Bat始终无法运行,上网找了半天才发现和Session0有关,也就是程序有不同级别的访问权限,Vista以上版本为了安全因 ...
- H5新特性---SVG--椭圆--直线--文本--滤镜(高斯滤镜--模糊)--地理定位
今天的目标 3.1:h5新特性--SVG--椭圆 <ellipse rx="" ry="" cx="" cy="" ...
- unity中的Culling Mask
摄像机按层渲染 Camera.cullingMask = 1<<x;//渲染x层 Camera.cullingMask = ~(1<<x);//渲染除去x的所有层 Camera ...
- 用pandas库修改excel文件里的内容,并把excel文件格式存为csv格式,再将csv格式改为html格式
假设有Excel文件data.xlsx,其中内容为: ID age height sex weight张三 1 39 181 female 85李四 2 ...