电梯第一次作业

第一次电梯较为简单,主要目的在于初步接触多线程,可以实现一些简单的操作。

在本次作业中,为了更好的了解多线程,我也阅读了一些代码,并据此仿写完成了第一次作业。

根据生产者和消费者的模式,读入线程即为生产者,电梯与调度器一起为消费者。仓库的容量为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第二单元的自白的更多相关文章

  1. oo第二单元作业总结

    oo第二单元博客总结 在第一单元求导结束后,迎来了第二单元的多线程电梯的问题,在本单元前两次作业中个人主要应用两个线程,采用“生产者-消费者”模式和共享数据变量的方式解决问题.在第三次作业中加入多个电 ...

  2. OO第二单元优化博客

    OO第二单元优化博客 第五次作业没有性能分,但是,我在这一单元的宗旨就是写一个日常生活中 最常见的那种电梯,所以第五次我没有写傻瓜电梯,而是直接写了个\(look\),和第六次基本相同. 总计一下lo ...

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

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

  4. OO第二单元小结

    OO第二单元小结 一.三次作业代码分析. 1.第一次作业 第一次作业是单部电梯的傻瓜调度,由于其过分傻瓜,所以第一次作业我只有两个类,一个main,一个电梯,main类负责不断从输入流中读取命令,如果 ...

  5. OO第二单元多线程电梯总结

    OO第二单元多线程电梯总结 第一次作业 设计思路 Input为输入线程,负责不断读取请求并将读到的请求放入调度器中. Dispatcher为调度器,是Input线程和Elevator线程的共享对象,采 ...

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

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

  7. 2020北航OO第二单元总结

    2020北航OO第二单元总结 前言 本单元考察基于多线程的电梯调度问题,成功让我从一个多线程小白到了基本掌握了使用锁来控制线程安全的能力,收获颇多(充分体验了迷茫地de一个又一个死锁bug的痛苦). ...

  8. OO第二单元——多线程(电梯)

    OO第二单元--多线程(电梯) 综述 第二单元的三次联系作业都写电梯,要求逐步提高,对于多线程的掌握也进一步加深.本次作业全部都给出了输入输出文件,也就避免了正则表达式判断输入输出是否合法的问题. 第 ...

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

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

随机推荐

  1. 关于接口测试工具postman与DHC介绍

    一.Postman背景介绍 用户在开发或者调试网络程序或者是网页B/S模式的程序的时候是需要一些方法来跟踪网页请求的,用户可以使用一些网络的监视工具比如著名的Firebug等网页调试工具.今天给大家介 ...

  2. 512MB内存VPS服务器安装宝塔WEB客户端建站 - 环境部署篇

    原本以为我们很多网友用VPS搭建网站不会用WEB面板,而采用一键包或者自己部署编译环境,但是最后发现其实目前我们使用WEB面板的还是挺多的,无论是免费还是付费的都有不少人使用.比如当初一直免费的AMH ...

  3. Java Swing实现展示数据,以及过滤排序

    public class RelationCostctrTable extends DefaultTableModel { public RelationCostctrTable(Vector< ...

  4. C++ 使用命名规范

    刚开始正式学习C++, 之前写了一个C++ 的小程序,但是并没有注意命名规范之类的.这一次重写一个类似的程序,再加上这几天学习 c++Prime(发现好喜欢这本书.虽然看的很慢,每一小节都感是满满的干 ...

  5. P3806 【模板】点分治1

    一道淀粉质的模版题,开始是暴力 #include <bits/stdc++.h> #define up(i,l,r) for(register int i = (l); i <= ( ...

  6. [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.2:compile (default-compile) on project taotao-manager-pojo: Compilation failure

    运行maven项目时报错 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.2:compi ...

  7. bgfx入门练习3——编译自定义Shader

    马个鸡,总算编译过了自定义Shader,在此感谢自己,感谢自己,以及感谢自己.没有自己的努力,我是不可能解决这个问题的,自己真是太叼了.妈的智障!!! 管方那屎一样的make工具根本没用,反正我是折腾 ...

  8. linux 挂载ntfs格式的硬盘

    一.安装ntfs 1.下载 sudo wget  https://tuxera.com/opensource/ntfs-3g_ntfsprogs-2017.3.23.tgz 2.解压 sudo tar ...

  9. java开发过程中,报错Dangling meta character '*' near index 0,解决办法

    1.split方法转化字符串为数组: String[] strPicArr = map.get("hw_pic").toString().split("*"); ...

  10. c语言构建哈希表

    /*哈希查找 *哈希函数的构造方法常用的有5种.分别是: *数字分析法 *平方取中法 *分段叠加 *伪随机数 *除留取余法 *这里面除留取余法比较常用 *避免哈希冲突常用的方法有4种: *开放定址法( ...