Github项目地址:https://github.com/LantyrLYL/WordCount

PSP表格:

PSP2.1

PSP阶段

预估耗时

(分钟)

实际耗时

(分钟)

Planning

计划

10

5

· Estimate

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

10

5

Development

开发

925

955

· Analysis

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

60

60

· Design Spec

· 生成设计文档

10

20

· Design Review

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

10

10

· Coding Standard

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

0

0

· Design

· 具体设计

30

30

· Coding

· 具体编码

480

480

· Code Review

· 代码复审

60

60

· Test

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

60

90

Reporting

报告

120

120

· Test Report

· 测试报告

90

90

· Size Measurement

· 计算工作量

5

5

· Postmortem & Process Improvement Plan

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

20

20

 

 

 

解题思路:

  看了需求说明,首先想到的是好像是C语言课程中有教到的从如何统计输入字符数和输入我单词数,还有就是将结果以某种文件形式输出的指定的位置。主要是if条件语句和++自增语句来实现,最后打印出来并输出。

程序设计实现过程:

 一个wc,其中包含3种函数。

main函数首先判断使用了需求中的哪种参数,并做输入判断正确与否。

getAllFilePath 函数是获取所有要进行读取判断的文件

wordcount 函数是对C文件中的内容按照需求进行分析,实现显示字符数、单词数、总行数等功能。

代码说明:

代码借鉴周志为同学的

for( i=0;i<chars.length;i++) {//统计每行字符数并加到字符总数里

numChar++;

}

numChar++;//加上每一行的换行

String[] tmp= str.split(" |,");

for(i=0;i<tmp.length;i++){

if(tmp[i].length()!=0){

if(extraList.size()!=0){//假如使用了停用词表

flagex=0;

for(j=0;j<extraList.size();j++) {

if (tmp[i].equals(extraList.get(j))) {

flagex = 1;

break;

}

}

if(flagex!=1) {//只统计不在停用词表里的单词

numWord++;

}

}

else{

numWord++;

}

}

}

if(chars.length>1) {//判断注释行

if(chars[0]=='/'&&chars[1]=='/'){//“//”开头注释行

numLineAnn++;

}

else if(chars[0]=='/'&&chars[1]=='*'){//“/*”开头注释行

numLineAnn++;

flagann=1;

}

else if(chars.length>2) {

if ((chars[0] == '{' || chars[0] == '}')) {//“{//”开头注释行

if (chars[1] == '/' && chars[2] == '/'){

numLineAnn++;

}

else if (chars[1] == '/' && chars[2] == '*') {//“{/*”开头注释行

numLineAnn++;

flagann = 1;

}

else if(flagann!=1) {//否则就是代码行

numLineCode++;

}

}

else if(flagann!=1) {

numLineCode++;

}

}

else if(flagann!=1) {

numLineCode++;

}

else {//在“/*”之后“*/”之前的注释

numLineAnn++;

for (i = 0; i < chars.length; i++) {//判断“/*”注释的结束“*/”

if (chars[i] == '*') {

if (i + 1 < chars.length)

if (chars[i + 1] == '/')

flagann = 0;

}

}

}

}

else {//空行

numLineEmpty++;//不超过一个可显示字符的空行

}

numLine++;

}

numChar--;//减去最后一行末尾不存在换行

测试设计过程:

对基本功能字符数等进行测试,对缺少参数以及参数不正确等进行测试,对扩展功能和高级功能进行测试。测试范围要较为全面,尽量测试到各种情况的发生,避免漏洞。

作出以下13个测试用例:

wc.exe

wc.exe -c test.c

wc.exe test.c

wc.exe *.c

wc.exe -c

wc.exe test.c -c

wc.exe test.c *.c

wc.exe -c -w -l -o test.c

wc.exe -c -w -l -o *.c

wc.exe -s -c -w -l -a *.c

wc.exe -s -c -w -l -a *.c -e b.c -o output.txt

wc.exe -s -c -w -l -a test.c -e b.c -o output.txt

wc.exe -c -w -l -a E:\MyEclipse\project\test\test.c -e b.c -o output.txt

参考文献链接:

邹欣老师的博客:http://www.cnblogs.com/xinz/archive/2011/10/22/2220872.html

手把手教你如何把jar文件,打包成jar文件以及转换为exe可执行文件:

http://blog.csdn.net/sunkun2013/article/details/13167099

WordCount编码测试的更多相关文章

  1. 软件测试第2周个人作业:WordCount编码测试

    一.Github地址 https://github.com/zhouyubei/WordCount 二.PSP表格 PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning ...

  2. WordCount编码和测试

    WordCount编码和测试 项目地址:https://github.com/handsomesnail/WordCount PSP表格 PSP2.1 PSP阶段 预估耗时(分钟) 实际耗时(分钟) ...

  3. Spring_Four -- 团队项目设计完善&编码测试

    团队项目设计完善&编码测试 1.文档<软件设计方案说明书>github地址:https://github.com/gzyt/SRS 2.项目集成开发环境 数据库:Mysql 5.0 ...

  4. 实验十一 团队作业7—团队项目设计完善&编码测试

    实验十一 团队作业7—团队项目设计完善&编码测试 实验时间 2018-6-8 Deadline: 2018-6-20 10:00,以团队随笔博文提交至班级博客的时间为准. 评分标准: 按时交 ...

  5. 《F4+2—团队项目设计完善&编码测试》

    1:根据OOD详细设计工作要点,修改完善团队项目系统设计说明书和详细设计说明       a.软件系统设计说明书的完善 将测试启动准则,测试结束准则,测试暂停/中止标准加到了测试计划中.将把在测试中会 ...

  6. JAVA字符编码测试

    几点注意: 1,ASCII码和ISO-8859-1都是单字节编码,ASCII码能表示128个字符,ISO-8859-1总共能表示256个字符.都不能表示中文,如果中文字符或其它不在IOS-8859码值 ...

  7. 软件质量与测试——WordCount编码实现及测试

    1.GitHub地址       https://github.com/noblegongzi/WordCount 2.PSP表格 PSP2.1 PSP 阶段 预估耗时 (分钟) 实际耗时 (分钟) ...

  8. WordCount 编码与测试

    word count github 项目地址:https://github.com/liuqiang666/wordCount PSP表格 PSP2.1  PSP阶段  预估耗时(小时)  实际耗时( ...

  9. WordCount编码与测试

    1. github项目地址:https://github.com/wwwwu/WordCount 2.PSP表格: PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning ...

随机推荐

  1. Node.js + Express

    相关链接: 1.https://www.jianshu.com/p/db4df1938eca 2.前端发起GET请求:http://localhost:3000/api/login?name=admi ...

  2. C#程序性能优化

    http://blog.csdn.net/scalzdp/article/details/34421639 程序中我们每一丝动作都会加大程序运行的负担,当刚开始学习程序的时候常常不会去考虑程序运行的效 ...

  3. linux 标准化

    Unix 1969 年诞生于 AT&T 贝尔实验室,并在 1973 年使用 C 语言进行了重写,从此就具有了很好的可移植性.但是当 AT&T 在 1984 年由于分拆而得以进入计算机领 ...

  4. mysql的备份恢复等操作

    备份数据库 shell> mysqldump -h host -u root -p dbname >dbname_backup.sql 恢复数据库 shell> mysqladmin ...

  5. HTML 各种鼠标手势

    <html> <body> <p>请把鼠标移动到单词上,可以看到鼠标指针发生变化:</p> <span style="cursor:au ...

  6. iOS 【资源篇】

    iOS9开发入门教程索引 Objective-C视频教程 O-c Blog 社区 畅游  http://www.9ria.com/ 苹果中文开发社区  http://www.cocoachina.co ...

  7. JSF拦截ajax请求并传递参数方法

    我们可以利用f:ajax做一些简单的ajax操作,但是遇到复杂的逻辑,它不能简单的去实现,jsf提供了一种方法,可以调用它内部的js方法去实现复杂的逻辑. 首先要在页面引入jsf的js文件: < ...

  8. 蓝桥杯 算法训练 ALGO-146 4-2找公倍数

    算法训练 4-2找公倍数   时间限制:1.0s   内存限制:256.0MB        查看参考代码 问题描述 这里写问题描述. 打印出1-1000所有11和17的公倍数. 样例输入 一个满足题 ...

  9. Java基础--CountDownLatch

    CountDownLatch是线程同步辅助类,它允许一个或多个线程wait直到countdown被调用使count为0. CountDownLatch是在java1.5被引入,存在于java.util ...

  10. (转)C#用Linq实现DataTable的Group by数据统计

    本文转载自:http://www.cnblogs.com/sydeveloper/archive/2013/03/29/2988669.html 1.用两层循环计算,前提条件是数据已经按分组的列排好序 ...