Pair Project —— Elevator Scheduler

时间:2021-07-18 18:09:06

结对编程人员

  12061153  刘丽萍

  12061154  冯飘飘

Pair Project —— Elevator Scheduler

说明结对编程的优点和缺点。

  结对编程的优点:

  以前都是自己一个人编程,对于相互结对或者团队编程都没有接触过。而自己在写代码时不可避免的会出现小错误,有时是打字错误,有时候是算法并没有完全用代码展现完整,而结对编程刚好实现了这种“两个程序员并排坐在一台电脑前,面对同一个显示器,使用同一个键盘,同一个鼠标一起工作。他们一起分析,一起设计,一起写测试用例,一起编码,一起单元测试,一起集成测试,一起写文档等”的环境,使我们的代码处在不断的复审当中,如果一个写代码的人边思考边写出来的有些许bug,结对的另一个人可以随时提醒他,这样避免了以后查找bug时的繁琐。再者,两个人相互交流自己的想法可以使工程的算法更完善,以一个更好更简便的方式实现,同时两个人在交流过程中得到学习,发现对方思维中的闪光点,可以更好的促进自身的进步。

  结对编程的缺点:

  由于每个人对于代码的理解不一样会造成复审效果的降低,并且两个人的交流也不是编程时时时刻刻都存在,有时会两人不在一块,导致一方不了解另一方的进度,而又要花时间去熟悉。

结对的每一个人的优点和缺点在哪里 (要列出至少三个优点和一个缺点)。

刘丽萍同学的优点:认真负责、思维独特、查bug有一套

      缺点:不太会写代码

冯飘飘同学的优点:能写代码、

      缺点:没耐心,不喜欢查bug

看教科书和其它资料中关于 Information Hiding, interface design, loose coupling 的章节,说明怎样利用这些好的设计方法。

Information Hiding : 类与类之间要相互利用私有变量时用定义的方法去调用获取私有变量,如get和set,可以很方便的访问变量。如这次的电梯调度,类与类之间用接口相互连接,很多信息只能通过接口类访问。

Interface Design : 接口设计是功能的封装,在写程序之前想好接口要实现的全部功能,如果后来用户需求改变了,则可以直接改变实现接口的类。

Loose Coupling : 松耦合,防止两个类之间交互性太强,改动一个会使另一个也有改动,可用接口连接两个类,使改动一个类的代码时不用担心会影响到另一个类。

描述Design by Contract, Code Contract这些做法的优缺点, 说明你是如何把它们融入你的作业中的。

  Contract契约是对Object对象行为的描述表达,也就是说:一个对象的行为方法做到什么样为合适?通过契约来约定是一种主要的设计方法。

  DBC分三种:  
    1.Post-conditions 后置条件postcondition 表示调用一个方法一定会得到的结果。类似断言Assertion,如果语言不支持断言,那么我们就必须自己写断言,也就是测试驱动了。    

    2.Pre-conditions 前置条件precondition ,预先保证后置条件必须满足前置条件。前置条件必须满足,后置条件必须实现,通过契约的前置嗯哼后置条件的结合,就不会出现有隐藏功能的obligations,这样,事情清清楚楚的摆出来,这样设计才能落实为代码。

    3.类不变量class invariant 表示对象状态的断言,执行完任何操作后都都应该被满足,不变量还是对聚合体进行完整性严格定义。

    引用自: http://www.jdon.com/36303

  有点是明确函数功能,充分保证函数实现时的正确性,也保证了代码的正确性和质量。

  缺点是对于程序语言有一定的要求,契约式编程需要一种机制来验证契约的成立与否。而断言显然是最好的选择,但是并不是所有的程序语言都有断言机制。那么强行使用语言进行模仿就势必造成代码的冗余和不可读性的提高。比如.NET4.0以前就没有assert的概念,在4.0后全面引入了契约式编程的概念,使得契约式编程的可用性大大提高了。此外,契约式编程并未被标准化,因此项目之间的定义和修改各不一样,给代码造成很大混乱,这正是很少在实际中看到契约式编程应用的原因。

  写代码时明确函数的功能,确保它传进去的参数需要满足什么条件,执行这个函数后又该满足什么条件,其中的不变式又是怎么写的保证执行完任何操作后都应该被满足,上个学期学习面向对象时吴际老师让我们学习并练习了这方面的内容。

通过截屏显示你是如何用VS 的unit test 来保证你写的类的质量的。显示unit test 对你的写的类(class) 的覆盖率

Pair Project —— Elevator Scheduler

画出UML 图显示各个实体之间的关系 (画一个图即可)

Pair Project —— Elevator Scheduler

说明你的算法的关键 (不必列出源代码), 以及独到之处。

  其实算法并没有什么……也没有独到之处。因为刚开始准备写一种比较智能的电梯,好容易写好代码以后,熬夜调了几天给的样例都不能全部跑通,最后实在没有办法了,第二天就是deadline,觉得这种智能型的实在不是我们能够驾驭的了的了。然后就采取了最普通的一种方法:只是在BUS的基础上判断每层是否有人可以进入或者出电梯然后再决定开不开门,给电梯加了一个是否开关门的信号,电梯来回从最高最低楼层之间运行,相较于BUS节约了开门的时间,但是觉得在高峰期这个完全不会有多大影响,但是结果竟然快了不少,也是很令我和我的小伙伴诧异的了……

  BUS

我们的算法

passenger1.xml  217.05             137.55           
passenger2.xml 949.133 447.023
passenger3.xml 1426.373 642.043