结对作业-stage_1

教学班 罗杰、任建班周五3、4节
gitlab项目地址 Here it is.
成员 周远航(3004) 李辰洋(3477)

结对编程体验

感受

  • 在前期设计时,两人合作可以收集更多资料,提供更多想法,有利于设计更完备的架构。
  • 一人写代码、一人领航员的配合方式及时对于能肉眼辨别的错误进行纠正,例如笔误、空指针错误等。

照片

设计阶段:对指导书进行精读,设计整体逻辑架构和类。

编程阶段:一人主笔,一人领航,交替进行。

在后期由于课业原因不方便同时在线时,我们还选择了分工协作的方式,每人负责相对独立的方法实现,push后对方对其进行检查。

设计思路

在初期设计时,我们充分融合了linux哲学核心思想:一切皆文件,并参考了Google开源java7文件系统实现源码,对于本次结对任务的初期架构进行了如下设计:

  • MyFileSystem

    文件系统核心类。记录了root和currentPosition两个目录入口。

  • DirectoryEntry

    目录入口类。用于管理目录下的所有文件(包括目录文件、普通文件)以及文件树的上下级关系。

  • File

    抽象类,“一切皆文件”中的“文件”,所有文件的父类,定义了一些文件的统一属性。

  • RegularFile

    普通文件,继承File抽象类。

  • Directory

    目录文件,继承File抽象类。

在完成本次任务的架构设计后,我们尝试使用TDD(测试驱动开发)的开发流程,使用JUnit4模块为MyFileSystem类需要实现的接口方法建立测试。通过基本设计框架的确定,以及测试模块的搭建,更好地指导了本次任务的开发和功能实现。

时间规划

PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟
Planning 计划 90 90
Estimate 估计这个任务需要多少时间 360 600
Development 开发 270 300
Analysis 需求分析 (包括学习新技术) 30 30
Design Spec 生成设计文档 10 10
Design Review 设计复审 (和同事审核设计文档) 10 10
Coding Standard 代码规范 (为目前的开发制定合适的规范) 0 0
Design 具体设计 30 30
Coding 具体编码 120 120
Code Review 代码复审 120 300
Test 测试(自我测试,修改代码,提交修改) 120 300
Reporting 报告 60 60
Postmortem & Process Improvement Plan 事后总结, 并提出过程改进计划 20 20

整体来看,设计和主要代码的编写过程比较顺利,后期的测试花费了比想象中更多的时间。

原文地址:https://www.cnblogs.com/CindyZhou/p/14574786.html