实验四  软件工程结对项目

2019-3-21/22

Deadline:2019-4-3 10:00,以博客发表日期为准

评分标准:

  • 按时交 - 有分(满分100分),检查项目包括:
  • 任务1部分(40分,代码和博客各20分)
  • 任务2部分(60分,代码和博客各30分)
  • 未提交项目源码到Github,代码部分不得分;未提交博客到班级博客上,博客部分不得分;
  • 任务2根据项目完成质量累计加分,完成基本功能原则上不超过满分60分,完成附加功能,给予加分;
  • 代码提交(代码规范,否则倒扣分);
  • 博文规范(行文清晰流畅,如果行文中涉及代码,请使用博客园自带的代码控件,或使用MarkDown的语法块)
  • 抄袭 - 倒扣本次作业分数

1、实验目的与要求

(1)体验软件项目开发中的两人合作,练习结对编程(Pair programming)。

(2)掌握Github上增量发布软件的操作方法。

2、实验相关知识

阅读现代软件工程—构建之法第4章内容,掌握以下概念:

1)结对编程

        以下图片是一个结对编程场景:两位学习伙伴坐在一起,面对着同一台显示器,使用着同一键盘,同一个鼠标,他们一起思考问题,一起分析问题,一起编写程序。

同学们是否尝试过两人合作的软件开发模式:本次实验,就让我们来体验一下结对编程的魅力。

关于结对编程的阐述可参见以下链接:

http://www.cnblogs.com/xinz/archive/2011/08/07/2130332.html

http://en.wikipedia.org/wiki/Pair_programming

2)代码规范

关于代码规范的其他参考博文:https://www.cnblogs.com/S031602240/p/10551854.html

关于github基础操作的参考链接:

参考文章:http://www.cnblogs.com/schaepher/p/4933873.html

参考文章:http://www.cnblogs.com/edisonchou/p/5990875.html

学习视频:https://www.bilibili.com/video/av10475153/ 

3、实验内容和步骤

任务1:两两自由结对,对结对方的《实验二 软件工程个人项目》的项目成果进行评价,具体要求如下:

  •  对项目博文作业进行阅读并进行评论,评论要点包括:博文结构、博文内容、博文结构与PSP中“任务内容”列的关系、PSP中“计划共完成需要的时间”与“实际完成需要的时间”两列数据的差异化分析与原因探究。
  •  克隆结对方项目源码到本地机器,阅读并测试运行代码,结合运行结果评论程序代码,评论要点包括:软件结构、代码规范、功能实现、人机交互等。
  •  尝试利用github中的Fork、Clone、Push、Pull request、Merge pull request对结对方仓库中的源码进行合作修改。

任务2:采用两人合作方式,设计开发一个英文文本统计分析软件,使之具有以下功能:

(1)实验2要求的功能;

(2)单词频数可视化柱状图要求是以下样式:

(3)统计该文本行数及字符数;

(4)各种统计功能均提供计时功能,显示程序统计所消耗时间(单位:ms);

(5)可处理任意用户导入的任意英文文本;

(6)人机交互界面要求GUI界面(WEB页面、APP页面都可);

(7)附加分功能:统计文本中除冠词、代词、介词之外的高频词;

(8)附加分功能:统计前10个两个单词组成的词组频率。

任务二两个合作项目实施要求:

  •  结对合作开发进度计划的要求:在项目正式开发之前,预估本次合作开发任务的PSP环节的消耗时间,并在PSP过程中统计实际耗时,填写PSP表格。
  • 尝试采用汉堡包法实施项目结对中两个人的沟通,关于汉堡包法的阐述参见:http://www.cnblogs.com/xinz/archive/2011/08/22/2148776.html
  • 理解领航员和驾驶员两种角色关系:两人都必须参与程序的编码工作,在结对编程中两个人轮流做对方的角色。
  • github仓库中的代码提交要体现两人合作过程,不能只看到最终的代码,至少有三次以上的代码签入记录, 能显示代码从最初的基本框架, 基本功能,到全部功能实现的构建过程 。
  • 编撰两人合作开发遵守共同认可的编码规范,并提交编码规范文档到github项目仓库根目录下。
  •  将包含任务2的源码以增量方式提交到指定同学注册Github账号下的项目仓库中,要求项目仓库中要能看到项目多次commit的记录,同时必须有两个人各自的commit记录。

任务3:完成博文作业

博文名称要求:学号1姓名+《英文文本统计分析》结对项目报告;

填写博文简要信息表:

项目

内容

这个作业属于哪个课程

任课教师博客主页链接

这个作业的要求在哪里

作业链接地址

课程学习目标

熟悉软件开发整体流程,提升自身能力

本次作业在哪个具体方面帮助我们实现目标

第一次体验一个完整的工程

博文作为两个任务总结的文字资料,请完整包含以下内容:

  •  任务1要给出所点评作业的博客、github链接地址,点评内容和点评心得;
  • 任务2需要给出结对项目源码在Github的仓库主页链接地址;
  • 任务2博文作为结对项目实施过程的文字资料,请完整包含下面7个部分:

          a.需求分析

          b.软件设计:使用类图

          c.核心功能代码展示:展示核心功能代码

          d. 程序运行:程序运行时每个功能界面截图

          e. 描述结对的过程,提供两人在讨论、细化和编程时的结对照片(非摆拍)

          f. 提供此次结对作业的PSP。

PSP2.1

任务内容

计划共完成需要的时间(min)

实际完成需要的时间(min)

Planning

计划

8

6

·       Estimate

·  估计这个任务需要多少时间,并规划大致工作步骤

8

6

Development

开发

82

88

··       Analysis

  需求分析 (包括学习新技术)

6

10

·       Design Spec

·  生成设计文档

5

6

·       Design Review

·  设计复审 (和同事审核设计文档)

4

6

·       Coding Standard

  代码规范 (为目前的开发制定合适的规范)

3

3

·       Design

  具体设计

10

12

·       Coding

  具体编码

36

21

·       Code Review

·  代码复审

7

9

·       Test

·  测试(自我测试,修改代码,提交修改)

13

21

Reporting

报告

9

6

··       Test Report

·  测试报告

3

2

·       Size Measurement

  计算工作量

2

1

·       Postmortem & Process Improvement Plan

·  事后总结 ,并提出过程改进计划

3

3

               g. 小结感受:两人合作真的能够带来1+1>2的效果吗?通过这次结对合作,请谈谈你的感受和体会。