Stage1:代码编写+单元测试

Github地址:

  https://github.com/245553473/wcPro.git


PSP表格:

PSP

PSP阶段

预估耗时(分钟)

实际耗时(分钟)

Planning

计划

10

5

Estimate

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

10

5

Development

开发

60

50

Analysis

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

5

5

Design Spec

生成设计文档

5

5

Design Review

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

5

5

Coding Standard

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

5

5

Design

具体设计

5

5

Coding

具体编码

40

30

Code Review

代码复审

5

5

Test

测试

20

10

Reporting

报告

10

10

Test Report

测试报告

10

10

Size Measurement

计算工作量

10

10

Postmortem & Process Improvement Plan

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

5

5

合计

205

165


接口的设计与实现:

  该程序设计了三个接口:String input(), List<WordInfo> handle(String input), void output(List<WordInfo>), WordInfo为包可见的数据类。

  WordInfo设计实现如下:

  该类用于保存各类不同的单词及统计数目,通过实现Java.lang.Comparable<T>接口并实现CompareTo方法,使得在对该对象数组进行排序时由数目进行排序,当数目相同时根据字符串的大小比较进行排序。

String input()方法为包可见内部类的输入方法,该方法根据内部处理类的路径path获得所需处理的文件名,并读取文件信息至字符串中并进行返回,其实现如下:

List<WordInfo> handle(String input) 函数为该程序的核心处理函数,将调用input()函数后输出的返回字符串作为输入并对其进行处理,保存至List中,并对其进行排序处理,将结果List集输出,其代码如下:

void output(List<WordInfo> handle) 函数为将核心处理函数输出的List集写入到本地文件"result.txt"中,其代码如下:


测试用例的设计:

用于测试的文件,将边缘字符信息分别复制多次、随机选择长文章进行测试、随机生成字符组成输入文件进行测试。白盒测试使用JUnit框架先对输入进行测试,输入测试能成功运行则将输入函数的输出作为处理函数的输入进行测试,若测试成功则将处理函数的结果作为输出函数的输入进行测试,最后将几个函数的整合进行测试。 黑盒测试通过.bat文件即命令行形式进行输入测试,检查输出的文件结果与预期结果的吻合度。

测试代码截图如下:


单元测试运行结果截图:

  Junit测试结果运行截图:

  


评价:

  通过不同核心处理方法所耗费的时间进行对比,该小程序在相同数据量的情况下所耗时间更短,对多种边缘测试输出都能很好地进行处理,程序性能良好,评价较优。


Stage2:静态测试

规范选择:

  选取阿里巴巴JAVA开发规范,其中方法名、参数名、成员变量、局部变量都统一使用lowerCamelCase风格,必须遵从驼峰形式。

组内分析:

  组内提交的代码基本符合JAVA编程规范,如我的代码存在耦合性较高的问题,代码间依赖性有待降低。

静态代码检查:

  选择工具:FindBugs 3.0.1

  下载链接:http://findbugs.sourceforge.net/

检查结果:

  

结果分析:

  对equals方法的重写不符合规范,由于这是对特殊情况的特殊处理,故暂且保留。

Stage3:性能测试和优化

 待更新。

WordCount 优化版测试小程序实现的更多相关文章

  1. WordCount优化版测试小程序实现

    Github地址:https://github.com/hcy6668/wordCountPro.git PSP表格: PSP  PSP阶段  预估耗时(小时)  实际耗时(小时)  Planning ...

  2. WordPress版微信小程序2.6版发布

    WordPress版微信小程序的完善和升级的工作一直都在进行中,我争取保证一个月可以出一个版本,希望通过一点点的改进,让这个开源产品日趋完美. 同时,pro版WordPress微信小程序也在紧锣密鼓的 ...

  3. WordPress版微信小程序3.2版发布

    WordPress版微信小程序(下称开源版)距离上次更新已经过去大半年了,在此期间,我开发新的专业版本-微慕小程序(下称微慕版),同时开源版的用户越来越多,截止到2018年11月26日,在github ...

  4. WordPress版微信小程序3.0版发布

    距离WordPress版微信小程序上一个版本的发布过去了一个月了.在此间,我的工作有些变化,加上正在开发新版本,目前开源版的完善和升级稍稍有些滞后. 虽然这个版本是3.0版,期间有个过渡的2.8版,不 ...

  5. WordPress版微信小程序2.4版发布

    自从发布2017年9月16日WordPress版微信小程序2.2.8版本后,这个一个多月来,WordPress版微信小程序,在经过一些比较小的更新后,今天发布阶段性的版本:2.4版 .这版本主要是功能 ...

  6. 优秀WordPress版微信小程序推荐(二)

    随着使用WordPress版微信小程序的用户越来越多,其中涌现不少优秀的小程序,无论UI设计还是功能上都远远超过我开源的程序.这次是推荐第二批优秀Wordpress版微信小程序,希望有更多的小程序的爱 ...

  7. WordPress版微信小程序2.2.8版发布

    距离上次更新已经一个月了,这期间对WordPress版微信小程序 做的不少小的更新和性能的优化,此次版本更新推出了两个比较重点的功能:点赞和赞赏.同时,优化了文章页面的功能布局,在评论区把常用的功能: ...

  8. WordPress版微信小程序2.1.5版发布

    WordPress版微信小程序功能已经基本完善,利用这套程序,搭配WordPress提供的rest api,WordPress网站的站长可以快速搭建属于自己的网站微信小程序 . WordPress版微 ...

  9. WordPress版微信小程序2.0版本发布

    利用业余时间对WordPress版微信小程序进行的升级,增加了一些功能,程序性能上做了一些优化.经过此次的版本升级,WordPress版微信小程序所需的基本功能已经具备. 开放源码地址:https:/ ...

随机推荐

  1. pip镜像源

    pip是用国内镜像源 https://pypi.python.org/http://pypi.douban.com/simple/ http://mirrors.aliyun.com/pypi/sim ...

  2. PHP数据结构之实现栈

    接着前面PHP数据结构来学习,今天写的是实现栈. <?php class stack //定义一个栈的类 { private $size; //栈的空间大小 private $top; // 栈 ...

  3. Java模版引擎:jsp、freemarker、velocity区别

    在java领域,表现层技术主要有三种:jsp.freemarker.velocity. jsp是大家最熟悉的技术优点:1.功能强大,可以写java代码2.支持jsp标签(jsp tag)3.支持表达式 ...

  4. Makefile中的路径

    使用 $(shell pwd) 可以在Makefile中指定为当前Makefile所在目录的路径

  5. 快速沃尔什变换(FWT)学习笔记

    概述 FWT的大体思路就是把要求的 C(x)=A(x)×B(x)  即 \( c[i]=\sum\limits_{j?k=i} (a[j]*b[k]) \) 变换成这样的:\( c^{'}[i]=a^ ...

  6. Azure VM从ASM迁移到ARM(一)

    Azure的IaaS有ASM和ARM两个版本,ARM的一些优点前面已经聊过很多了.ARM有更细的管理颗粒度,更多的功能等. 如果想从ASM迁移到ARM,目前有两类方法可以实现: 1. Azure平台支 ...

  7. SpringMVC的环境搭建

    MyBatis框架-->持久层框架-->Object[对象]Relation[关系型数据库]Mapping[在MyBatis的体现是哪个映射文件中国的<resultMap>标签 ...

  8. MyBatis 批量插入数据对插入记录数的限制

    <基于 MyBatis 框架的批量数据插入的性能问题的探讨>(作者:魏静敏 刘欢杰 来源:<计算机光盘软件与应用> 2013 年第 19 期)中提到批量插入的记录数不能超过10 ...

  9. Vue开发模板简介

    1.    传统发开模式的问题 用传统模式引用vue.js以及其他的js文件的开发方式,会产生一些问题. 基于页面的开发模式:传统的引用vue.js以及其他的js文件的开发方式,限定了我们的开发模式是 ...

  10. redis学习五 集群配置

    redis集群配置 0,整体概述      整体来说就是:      1,安装redis      2,配置多个redis实例      3,安装 ruby和rubygems      4,启动red ...