WordCount编码测试
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编码测试的更多相关文章
- 软件测试第2周个人作业:WordCount编码测试
一.Github地址 https://github.com/zhouyubei/WordCount 二.PSP表格 PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning ...
- WordCount编码和测试
WordCount编码和测试 项目地址:https://github.com/handsomesnail/WordCount PSP表格 PSP2.1 PSP阶段 预估耗时(分钟) 实际耗时(分钟) ...
- Spring_Four -- 团队项目设计完善&编码测试
团队项目设计完善&编码测试 1.文档<软件设计方案说明书>github地址:https://github.com/gzyt/SRS 2.项目集成开发环境 数据库:Mysql 5.0 ...
- 实验十一 团队作业7—团队项目设计完善&编码测试
实验十一 团队作业7—团队项目设计完善&编码测试 实验时间 2018-6-8 Deadline: 2018-6-20 10:00,以团队随笔博文提交至班级博客的时间为准. 评分标准: 按时交 ...
- 《F4+2—团队项目设计完善&编码测试》
1:根据OOD详细设计工作要点,修改完善团队项目系统设计说明书和详细设计说明 a.软件系统设计说明书的完善 将测试启动准则,测试结束准则,测试暂停/中止标准加到了测试计划中.将把在测试中会 ...
- JAVA字符编码测试
几点注意: 1,ASCII码和ISO-8859-1都是单字节编码,ASCII码能表示128个字符,ISO-8859-1总共能表示256个字符.都不能表示中文,如果中文字符或其它不在IOS-8859码值 ...
- 软件质量与测试——WordCount编码实现及测试
1.GitHub地址 https://github.com/noblegongzi/WordCount 2.PSP表格 PSP2.1 PSP 阶段 预估耗时 (分钟) 实际耗时 (分钟) ...
- WordCount 编码与测试
word count github 项目地址:https://github.com/liuqiang666/wordCount PSP表格 PSP2.1 PSP阶段 预估耗时(小时) 实际耗时( ...
- WordCount编码与测试
1. github项目地址:https://github.com/wwwwu/WordCount 2.PSP表格: PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning ...
随机推荐
- RedHat5.8 编译内核驱动 合成initrd.img
/******************************************************************* * RedHat5.8 编译内核驱动 合成initrd.img ...
- Agc001_D Arrays and Palindrome
传送门 题目大意 给定一个元素和为$N$的有$M$个数的序列$A$,请你可以$A$元素排列的顺序,并需要构造一个有$K$个($K$可以自己定)数的数列,使得任意一个长度为$N$的字符串,若满足:前$A ...
- 「BJOI2018」链上二次求和
「BJOI2018」链上二次求和 https://loj.ac/problem/2512 我说今天上午写博客吧.怕自己写一上午,就决定先写道题. 然后我就调了一上午线段树. 花了2h找到lazy标记没 ...
- javascript之面试题精讲
from:http://blog.csdn.net/q121516340/article/details/51332454 1,检测数组的几种方式: Array.isArray(); es5 toSt ...
- eclipse Git & maven 安装
JDK安装请自行百度. Maven是免安装的.压缩包解压完成后.如解压后放在D:\Server\maven下.接下来配置maven的环境变量: 系统变量:MAVEN_HOME = D:\Server\ ...
- 配置进程外Session
配置进程外Session: (1)将服务器Session信息存储在进程外 <1> 首先,开启asp.net state 服务: 控制面板 -> 程序和功能 -&g ...
- 山区建小学(区间DP)
山区建小学 时间限制: 1 Sec 内存限制: 128 MB提交: 17 解决: 5[提交][状态][讨论版][命题人:quanxing] 题目描述 政府在某山区修建了一条道路,恰好穿越总共m个村 ...
- AngularJS:应用
ylbtech-AngularJS:应用 1.返回顶部 1. AngularJS 应用 现在是时候创建一个真正的 AngularJS 单页 Web 应用(single page web applica ...
- Python数据库(二)-Mysql数据库插入数据
通过python连接mysql数据库,并插入数据 # -*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import pymysql ...
- nfs cron shell 作业
作业一: nginx反向代理三台web服务器,实现负载均衡 所有的web服务共享一台nfs的存储 2台服务器 nginx [lb] :101.200.206.6 nginx [web]:101.200 ...