电梯第一次作业

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

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

根据生产者和消费者的模式,读入线程即为生产者,电梯与调度器一起为消费者。仓库的容量为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. linux 网络虚拟化: network namespace 简介

    linux 网络虚拟化: network namespace 简介 network namespace 是实现网络虚拟化的重要功能,它能创建多个隔离的网络空间,它们有独自的网络栈信息.不管是虚拟机还是 ...

  2. 数据库子查询和join的比较

    子查询进行SELECT语句嵌套查询,可以一次完成很多逻辑上需要多个步骤才能完成的SQL操作.子查询虽然很灵活,但是执行效率并不高. select goods_id,goods_name from go ...

  3. Markdown使用小总结[不定时更新]

    title: Markdown使用小总结 date: 2019-03-27 10:09:19 tags: Markdown --- 鸽了这么久,Markdown使用下降,因此写一篇博客来总结一下至今( ...

  4. EasyPR源码剖析(1):概述

    EasyPR(Easy to do Plate Recognition)是本人在opencv学习过程中接触的一个开源的中文车牌识别系统,项目Git地址为https://github.com/liuru ...

  5. python 打包成 windows .EXE

    1. 升级pip python -m pip install --upgrade pip 2.安装 pyinstall (打包程序) pip install pyinstaller 3 开始打包(打包 ...

  6. GUI学习之四——QWidget控件学习总结

    上一章将的QObject是PyQt里所有控件的基类,并不属于可视化的控件.这一章所讲的QWidget,是所有可视化控件的基类. QWidget包含下面几点特性 a.控件是用户界面的最小的元素 b.每个 ...

  7. Gym - 101848B Almost AP 暴力

    题目链接:http://codeforces.com/gym/101848/problem/B 给出一串数字要你最多改动三个数字使这一串数字成为等差数列.因为最多改动三个数字所以可以先求出相邻两项的差 ...

  8. maven学习四:maven集成jetty插件发布web项目 标签: maven

    http://blog.csdn.net/u014079773/article/details/50167833

  9. #2019-2020-4 实验二面向对象程序设计《Java开发环境的熟悉》实验报告

    2019-2020-4 实验二面向对象程序设计<Java开发环境的熟悉>实验报告 一.面向对象程序设计-1 ①实验要求: 1.参考 http://www.cnblogs.com/roced ...

  10. js 对象与json的转化

    1.将对象转换为JSON格式字符串 JSON.stringify(object) 2.将JSON字符串转换为对象 JSON.parse(jsonString);