一、基本功能

GITHUB项目地址:https://github.com/LongtermPartner/ExtendWordCount

PSP表格填写:

Planning

计划

20

20

· Estimate

· 估计这个任务需要多少时间

10

5

Development

开发

160

100

· Analysis

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

30

20

· Design Spec

· 生成设计文档

20

10

· Design Review

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

20

0

· Coding Standard

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

30

10

· Design

· 具体设计

10

10

· Coding

· 具体编码

50

50

· Code Review

· 代码复审

20

30

· Test

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

60

100

Reporting

报告

30

30

· Test Report

· 测试报告

30

40

· Size Measurement

· 计算工作量

10

10

· Postmortem & Process Improvement Plan

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

20

10

合计

500

455

对接口的实现——output:

输出功能的实现是整个基本功能部分最简单的模块,将count and sort模块产生的计数结果输出到指定文件或默认文件,只需要利用以下代码即可:

public class Output {

    public static void output(ArrayList<Entry<String, Integer>> list, File outputFile) throws IOException{

          if(outputFile==null){

             outputFile=new File("result.txt");

             }

            //FileWriter fW=new FileWriter(outputFile,true);

          FileWriter fW=new FileWriter(outputFile);

             BufferedWriter bw=new BufferedWriter(fW);

        bw.close();

    }

}

需求说明中对输出的要求:输出单词词频从高到低排序的前100个(从1到100),每行分别给出一个单词及其词频,单词按小写形式给出,单词和词频之间空一格。对于单词词频相同的情况,按照单词所包含的每个字母从a到z的次序依次排列。输出文件末尾多余的换行符应去除。

在output模块中进行的有输出词频前100个,和计数排序模块一样使用简单的map工具,其他功能在主函数中实现。

测试用例的设计:

输出模块功能比较简单,由于本程序已经指定输出文件,故测试内容主要集中于从countandsort模块输入的内容多样性,包括:

①输入的单词-词频组数为零个、一个、多个时,针对需求说明又有>100组,=100组等。

②输入的单词-词频是否字母/词频数相同。针对词频数和单词分别测试。

③对词频数相同的情况进行分类测试。

WordCount优化-第四周小组作业-LMLPHP

WordCount优化-第四周小组作业-LMLPHP

单元测试的运行:

对输出模块编写了脚本进行测试,所有用例均通过。

测试质量评价:

由于输出模块功能较为简单,用例针对性可能会有重复。

覆盖率较高,但效率可能不尽如人意。

待测模块能够满足用户的功能需求。

小组贡献分:0.22

二、拓展功能

本小组使用java完成此任务,故选用的开发规范文档是《阿里巴巴Java开发手册》,实际使用的是 手册中编程规约目录下(一)命名风格、(二)常量定义、

(三)代码格式、(四)OOP规约

代码中的规范化问题有:

①在修改代码的过程中有增删,导致代码缩进不够规范。

②对"{"和"}"的使用不够规范,每个大括号没有另起。

③删减修改造成的冗余空白行。

④不规范的空格使用。

⑤变量命名采用缩写时大小写不规范。

代码如下:

    public static void output(ArrayList<Entry<String, Integer>> list, File outputFile) throws IOException{
//输出实现
if(outputFile==null){
outputFile=new File("result.txt"); }
//FileWriter fW=new FileWriter(outputFile,true);
FileWriter fW=new FileWriter(outputFile);
BufferedWriter bw=new BufferedWriter(fW); String str="";

所遵循的好的规范:

因为并不是一个有良好编码习惯的人,从前基本没有了解过这方面的规范,所以代码中规范性问题更多些。

所使用的静态代码检查工具:PMD

对上述代码进行扫描。

整个小组代码出现的问题整合及解决方法:

上述问题在其他同学的代码中也有出现,因为进行到此的时候已经是假期了所以没有来得及整合。

有了相关信息了解,加强规范化意识,养成良好的编码习惯就可以规避其中很大一部分。

三、高级功能

以下测试由小组成员讨论完成

测试数据集:

WordCount优化-第四周小组作业-LMLPHP

如图,测试数据集使用了一个1600多行的文本文件test.txt,其中包含了各类单词。

处理时长:

WordCount优化-第四周小组作业-LMLPHP

如图,经过多次试验,处理此测试数据集的时间在300ms~400ms左右。

同行评审:

每位小组成员都作为作者、讲解员、评审员、记录员等身份进行了评审。

经过评审,我们得出结论:影响程序性能的主要因素是计数和排序两个模块,即计数时对单词的判定方法和排序的算法快慢。

实际测试:

通过测试,我们发现制约程序性能指标的主要因素是计数和排序两方面,即和同行评审结果相似。

软件开发、软件测试、软件质量的关系:

本次作业中,在完成了基本功能也就是初期代码的编写后,我们就编写了测试用例进行了测试,通过测试发现问题和漏洞,再对代码进行改进,重复此过程直到所有的测试用例全部通过。

可以说,软件测试贯穿了这次开发的整个过程,一次次改善了软件质量,最终以一个更好的状态完成开发。

05-17 15:06