软工项目WordCount
1.Github项目地址:https://github.com/JameMo/WordCount-for-C
2.在程序的各个模块的开发上耗费的时间:
|
PSP2.1 |
Personal Software Process Stages |
预估耗时(分钟) |
实际耗时(分钟) |
|
Planning |
计划 |
10 |
8 |
|
· Estimate |
· 估计这个任务需要多少时间 |
10 |
8 |
|
Development |
开发 |
350 |
350 |
|
· Analysis |
· 需求分析 (包括学习新技术) |
150 |
120 |
|
· Design Spec |
· 生成设计文档 |
20 |
30 |
|
· Design Review |
· 设计复审 (和同事审核设计文档) |
20 |
15 |
|
· Coding Standard |
· 代码规范 (为目前的开发制定合适的规范) |
10 |
10 |
|
· Design |
· 具体设计 |
30 |
25 |
|
· Coding |
· 具体编码 |
70 |
90 |
|
· Code Review |
· 代码复审 |
20 |
30 |
|
· Test |
· 测试(自我测试,修改代码,提交修改) |
30 |
30 |
|
Reporting |
报告 |
60 |
60 |
|
· Test Report |
· 测试报告 |
30 |
35 |
|
· Size Measurement |
· 计算工作量 |
20 |
15 |
|
· Postmortem & Process Improvement Plan |
· 事后总结, 并提出过程改进计划 |
10 |
10 |
|
合计 |
420 |
418 |
3. 解题思路:
首先,认真审题,将题目中的具体需求写出来,然后再思考具体模块。然后,细化到各个模块内,每个模块如何实现,如何满足需求,并判断自己是否能做到。接下来,将自己所需要的知识写下,并寻找自己所需要的资料,逐一学习,并开始着手打码。最后,对每个模块进行测试,并编辑博文。
4.设计实现过程:
代码一共含有九个函数(其中包含主函数)。其中char_num、word_num、line_num、blankline_num、codeline_num、commentline_num这六个函数为主要功能函数,而main、traverse两个函数主要是用来调用上面的六个函数,还有最后一个fun函数则是用来将两个字符串连接。
5.代码说明:
头文件:
#include<stdio.h>
#include<io.h>
具体函数:
①char_num函数
1 void char_num(char *file)
2 {
3 //查询file.c文件中字符数目的函数
4 int num = 0;
5 FILE *f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while((a = fgetc(f))!=EOF)
11 {
12 //避开空格、换行、Tab字符
13 if(a!=' ' && a!='\n' && a!='\t')
14 num++;
15 }
16 }
17 else
18 {
19 printf("this file does not exist.\n");
20 }
21 fclose(f);
22 printf("char_num:%d\n",num);
23 }
②word_num函数
1 void word_num(char *file)
2 {
3 //查询file.c文件中单词数目的函数
4 int num = 0,flag;
5 FILE *f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while(!feof(f))
11 {
12 a = fgetc(f);
13 //判断字符是否为大小写字母
14 if((a<='z'&&a>='a')||(a<='Z'&&a>='A'))
15 flag = 1;
16 //计算单词数目
17 else if(flag)
18 {
19 num++;
20 flag = 0;
21 }
22 }
23 }
24 else
25 {
26 printf("this file does not exist.\n");
27 }
28 fclose(f);
29 printf("word_num:%d\n",num);
30 }
③line_num函数
1 void line_num(char *file)
2 {
3 //查询file.c文件中行数的函数
4 int num = 1;
5 FILE *f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while(!feof(f))
11 {
12 a = fgetc(f);
13 //换行符为计数标志
14 if(a=='\n')
15 num++;
16 }
17 }
18 else
19 {
20 printf("this file does not exist.\n");
21 }
22 fclose(f);
23 printf("line_num:%d\n",num);
24 }
④blankline_num函数
1 void blankline_num(char *file)
2 {
3 //查询file.c文件中空行数的函数
4 int num = 0,count = 0,flag;
5 FILE *f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while(!feof(f))
11 {
12 a = fgetc(f);
13 //换行时进行判断
14 if(a=='\n')
15 {
16 //字符少于、等于1和不为注释行时进行计数
17 if(count<=1&&flag!=2)
18 num++;
19 count = 0;
20 }
21 else if(a!='\t'&&a!=' '&&a!='/')
22 count++;
23 else if(a=='/')
24 flag++;
25 }
26 }
27 else
28 {
29 printf("this file does not exist.\n");
30 }
31 fclose(f);
32 printf("blankline_num:%d\n",num);
33 }
⑤codeline_num函数
1 void codeline_num(char *file)
2 {
3 //查询file.c文件中代码行数的函数
4 int num = 0,count = 0,flag = 0;
5 FILE *f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while(!feof(f))
11 {
12 a = fgetc(f);
13 //先作字符分类,再进行判断
14 if(a!=' '&&a!='\t'&&a!='\n'&&a!='/')
15 count++;
16 else if(a=='\n')
17 {
18 if(count>1&&flag!=2)
19 num++;
20 count = 0;
21 }
22 else if(a=='/')
23 {
24 flag++;
25 }
26 }
27 }
28 else
29 {
30 printf("this file does not exist.\n");
31 }
32 fclose(f);
33 printf("codeline_num:%d\n",num);
34 }
⑥commentline_num函数
1 void commentline_num(char *file)
2 {
3 //查询file.c文件中注释行数的函数
4 int num = 0,flag = 0;
5 FILE* f;
6 char a;
7 f = fopen(file,"r");
8 if(f!=NULL)
9 {
10 while(!feof(f))
11 {
12 a = fgetc(f);
13 //换行时标志归零
14 if(a=='\n')
15 {
16 flag = 0;
17 }
18 //对注释符进行计数
19 else if(a=='/')
20 {
21 flag++;
22 if(flag==2)
23 num++;
24 }
25 }
26 }
27 else
28 {
29 printf("this file does not exist.\n");
30 }
31 fclose(f);
32 printf("commentline_num:%d\n",num);
33 }
⑦fun函数
1 char *fun(char *c1,char *c2)
2 {
3 //将两个字符串进行连接
4 int i,j;
5 char *ch;
6 for(i=0;c1[i]!='*';i++)
7 {
8 ch[i]=c1[i];
9 }
10 for(j=0;c2[j]!='\0';j++,i++)
11 {
12 ch[i]=c2[j];
13 }
14 ch[i]='\0';
15 return ch;
16 }
⑧traverse_all函数
1 void traverse_all(char *file_folder)
2 {
3 //文件夹内所有*.c文件的所有信息
4 long handle;
5 char *ch;
6 struct _finddata_t fileinfo;
7 handle = _findfirst(file_folder,&fileinfo);
8 if(handle==-1L)
9 return;
10 do
11 {
12 printf("file name:%s\n",fileinfo.name);
13 ch = fun(file_folder,fileinfo.name);
14 char_num(ch);
15 word_num(ch);
16 line_num(ch);
17 blankline_num(ch);
18 codeline_num(ch);
19 commentline_num(ch);
20 }while(!_findnext(handle,&fileinfo));
21 }
⑨main函数
1 int main(int a,char* arg[])
2 {
3 //运行wc.exe的主函数。
4 FILE *f;
5 while(1)
6 {
7 //判断文件是否存在
8 //对文件作不同的处理
9 if((f=fopen(arg[2],"r"))==NULL)
10 {
11 if(!strcmp("-s",arg[1]))
12 {
13 traverse_all(arg[2]);
14 }
15 else
16 {
17 printf("NO FILE NOW\n\n");
18 scanf("%s%s%s",arg[0],arg[1],arg[2]);
19 continue;
20 }
21 }
22 else if(!strcmp("-c",arg[1]))
23 {
24 char_num(arg[2]);
25 }
26 else if(!strcmp("-w",arg[1]))
27 {
28 word_num(arg[2]);
29 }
30 else if(!strcmp("-l",arg[1]))
31 {
32 line_num(arg[2]);
33 }
34 else if(!strcmp("-a",arg[1]))
35 {
36 blankline_num(arg[2]);
37 codeline_num(arg[2]);
38 commentline_num(arg[2]);
39 }
40 else
41 {
42 printf("Out of specification\n\n");
43 }
44 scanf("%s%s%s",arg[0],arg[1],arg[2]);
45 }
46 return 0;
47 }
6.测试运行。
测试文件:
①testing1.c

②testing2.c

测试结果:
①-c

②-w

③-l

④-a

⑤-s

7.项目小结:
这次项目是我做得最完整的一次项目,而且也是我的第一次做如此困难的项目。在这次项目中,我懂得了如何使用PSP去控制自己做项目的时间,此外,PSP还教会了我如何去完成一个项目。同时在这次项目中学会使用了许多新的函数,利用这些函数可以打开文件以及文件夹,从而在文件层面进行操作。我认为此次项目的最大的缺点是没有用到其他语言去实现,只停留在C语言中。
软工项目WordCount的更多相关文章
- 关于软工项目beta版本
项目总结 项目成员: 黄丰润 031302307 王旭銮 031302320 张家俊 031302329 张晓燕 031302343 项目完成度:实现了专业信息填写.查看,教师信息填写,报课和查看课表 ...
- 2018软工项目UML设计(团队)
团队信息 队名:火箭少男100 本次作业课上成员 短学号 名 本次作业博客链接 2507 俞辛(临时队长) https://www.cnblogs.com/multhree/p/9821080.htm ...
- 【软工项目Beta阶段】博客目录
绝不划水队Beta冲刺阶段博客目录 一.Scrum Meeting 第十周会议记录 第十一周会议记录 二.测试报告 Beta阶段测试报告 三.习得的软工原理/方法/技能? (1)在进行OUC-Mark ...
- 【软工项目Beta阶段】第11周Scrum会议博客
第十一周会议记录 小组GitHub项目地址https://github.com/ouc-softwareclass/OUC-Market 小组Issue地址https://github.com/ouc ...
- 软工作业WordCount
github项目传送门:https://github.com/zzh010/My-wc 一.WC 项目要求 wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数.这个项目要求写一个命 ...
- 【软工项目Beta阶段】第10周Scrum会议博客
第十周会议记录 小组GitHub项目地址https://github.com/ouc-softwareclass/OUC-Market 小组Issue地址https://github.com/ouc- ...
- 玩下软工项目,第一轮--全局Context的获取,SQLite的建立与增删改查,读取用户通话记录信息
项目的Github地址:https://github.com/ggrcwxh/LastTime 采用基于git的多人协作开发模式 软件采用mvc设计模式,前端这么艺术的事我不太懂,交给斌豪同学去头疼了 ...
- 【软工项目Beta阶段】绝不划水队OUC-Market版本测试报告
我们在开发APP的时候进行了软件的测试,同时发现了一些BUG,如下: bug 我的:与各种页面之间的交互不灵活 登录与注册:记住密码功能不完善 商场主界面:搜索功能还没有完善 收藏功能:与数据库的交互 ...
- 软工读书笔记 week 8 —— 《疯狂的程序员》
这次接着上一次的进度继续阅读,并将其中感悟较深的几点记录如下. 程序员是一个幕后工作者 书中绝影给医院写软件,而医生(用户)只是评价这个软件好不好用,而不会去评价写这个软件的程序员优不优秀. ...
随机推荐
- 这个Map你肯定不知道,毕竟存在感确实太低了。
这是why哥的第 75 篇原创文章 从Dubbo的优雅停机说起 好吧,其实本文并不是讲 Dubbo 的优雅停机的. 只是我在 Dubbo 停机方法 DubboShutdownHook 类中,看到了这样 ...
- Markdown文档示例
目录 我是大标题,和一级标题长得一样 我是次级标题,和二级标题长得一样 这是一级标题 这是二级标题 一直到六级标题 列表 表格 分割线 字体 超链接 插入图片 引用 代码块 注意下面每一个标记如果和内 ...
- 目录方式扩展swap分区大小
1.查看swap大小:free -m (-k|m|g) --以k|m|g为单位用去尾法显示大小 [root@lbg tmp]# free -m total used ...
- Ubuntu12.10 设置默认命令行启动
在虚拟机当中安装ubuntu12.10的时候默认把图形界面给装上了,由于不需要使用桌面,所以为了省去每次进入到图形界面然后再用ctrl+F1的方式切换到命令行的步骤,希望能够默认进入的是命令行模式,那 ...
- deepin 安装最新版node
安装npm sudo apt install npm 安装node sudo npm install -g n 升级node到稳定版 sudo n stable 升级到最新版 sudo n lates ...
- python any,call,init,下划线知识汇总
python补充 any() [来自菜鸟教程] any() 函数用于判断给定的可迭代参数 iterable 是否全部为 False,则返回 False,如果有一个为 True,则返回 True. 元素 ...
- Weblogic CVE-2020-2551漏洞复现&CS实战利用
Weblogic CVE-2020-2551漏洞复现 Weblogic IIOP 反序列化 漏洞原理 https://www.anquanke.com/post/id/199227#h3-7 http ...
- Python:利用Entrez库筛选下载PubMed文献摘要
一个不是学生物的孩子来搞生物,当真是变成了一块废铁啊,但也是让我体会到了一把生物信息的力量. 废话不多说,开整! 任务:快速高效从PubMed上下载满足条件的文献PMID.标题(TI).摘要(AB). ...
- 企业级工作流解决方案(七)--微服务Tcp消息传输模型之消息编解码
Tcp消息传输主要参照surging来做的,做了部分裁剪和改动,详细参见:https://github.com/dotnetcore/surging Json-rpc没有定义消息如何传输,因此,Jso ...
- .NET 5 ORM 八大实用技巧 干货 - SqlSugar ORM
介绍 sqlsugar已经在第一时间完美兼容.NET5并且已经有人在使用了, 很多人都担心用了开源框架遇到问题无法解决,导致前功尽弃,使用SqlSugar你大可放心,除了有详细文档和几年的大量用户积累 ...