第二次oo总结

Posted tdnss-18

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第二次oo总结相关的知识,希望对你有一定的参考价值。

前言

  这三次的oo作业,相对于之前的难度是一个跃升。从大一的第二课堂,数据结构,到大二上学期的计组使用verilog编程,都没有接触过多线程这样的编程思想,尤其是第五次作业刚开始的时候,多线程确实让对多线程一知半解的我大费周章。不过在完成几次作业之后,也确实感觉到了多线程逻辑的简化和方便,但同时也会带来各种各样的麻烦。

 

第一次作业

  技术分享图片

技术分享图片

 

  第一次作业由于是多线程的首次尝试,可以看出不同对象之间的调用非常杂乱,首先我使用main类作为主类启动三个elevator对象作为三部电梯线程,然后三部电梯每个电梯中有自己需要执行的请求队列,读取和处理请求也是不同的线程,处理请求和三个对象之间有交互。处理请求线程可以读取三个对象的状态,然后将指令分给应该执行请求的电梯的队列。另外,还有诸如LIght这样的其他类,用于对于同质请求的判断。

  显而易见,这样Command类作为请求处理的类运行的复杂度就会非常大。

 

第二次作业

技术分享图片

技术分享图片

技术分享图片

 

  第二次作业的IFTTT由于指导书有很多不明白的地方,所以写的代码就很复杂,具体来说就是main类作为主类调用输入处理方法,输入处理将所有需要监控的对象归纳出来以后,启动对应的监控对象,我对于每一类的监控都写了一个类,由于对于线程安全的方法还不是很理解,所以我这里只使用了一个全局变量来确保线程的安全,但是这样还是有可能造成线程不安全的问题。

  由于输入处理完请求后需要对于指令进行判断并启动对应的监控线程,所以处理类的复杂度很高。

 

第三次作业

技术分享图片

技术分享图片

技术分享图片

  第三次作业的类之间的联系就相对规整了一些,原因其一是使用了提供的gui类,二是因为逻辑相对简单。所以第三次作业的逻辑更加清晰一些,但是我的第三次作业仍有不足的地方,就是内存开的过大,而且还有一些我无法处理的误差。

 

后记

  这几次作业没有通宵过了,只是会看到凌晨4点的北京,感觉可能是相对来说更加适应了一些oo这门课,但是对于多线程的掌握仍有很大不足,应该更加勤勉一些。

 

以上是关于第二次oo总结的主要内容,如果未能解决你的问题,请参考以下文章

第二次oo总结

OO第二次课程总结

oo第二次总结

oo第二次博客总结

oo第二次总结

OO第二次总结