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的更多相关文章

  1. 关于软工项目beta版本

    项目总结 项目成员: 黄丰润 031302307 王旭銮 031302320 张家俊 031302329 张晓燕 031302343 项目完成度:实现了专业信息填写.查看,教师信息填写,报课和查看课表 ...

  2. 2018软工项目UML设计(团队)

    团队信息 队名:火箭少男100 本次作业课上成员 短学号 名 本次作业博客链接 2507 俞辛(临时队长) https://www.cnblogs.com/multhree/p/9821080.htm ...

  3. 【软工项目Beta阶段】博客目录

    绝不划水队Beta冲刺阶段博客目录 一.Scrum Meeting 第十周会议记录 第十一周会议记录 二.测试报告 Beta阶段测试报告 三.习得的软工原理/方法/技能? (1)在进行OUC-Mark ...

  4. 【软工项目Beta阶段】第11周Scrum会议博客

    第十一周会议记录 小组GitHub项目地址https://github.com/ouc-softwareclass/OUC-Market 小组Issue地址https://github.com/ouc ...

  5. 软工作业WordCount

    github项目传送门:https://github.com/zzh010/My-wc 一.WC 项目要求 wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数.这个项目要求写一个命 ...

  6. 【软工项目Beta阶段】第10周Scrum会议博客

    第十周会议记录 小组GitHub项目地址https://github.com/ouc-softwareclass/OUC-Market 小组Issue地址https://github.com/ouc- ...

  7. 玩下软工项目,第一轮--全局Context的获取,SQLite的建立与增删改查,读取用户通话记录信息

    项目的Github地址:https://github.com/ggrcwxh/LastTime 采用基于git的多人协作开发模式 软件采用mvc设计模式,前端这么艺术的事我不太懂,交给斌豪同学去头疼了 ...

  8. 【软工项目Beta阶段】绝不划水队OUC-Market版本测试报告

    我们在开发APP的时候进行了软件的测试,同时发现了一些BUG,如下: bug 我的:与各种页面之间的交互不灵活 登录与注册:记住密码功能不完善 商场主界面:搜索功能还没有完善 收藏功能:与数据库的交互 ...

  9. 软工读书笔记 week 8 —— 《疯狂的程序员》

    这次接着上一次的进度继续阅读,并将其中感悟较深的几点记录如下.      程序员是一个幕后工作者 书中绝影给医院写软件,而医生(用户)只是评价这个软件好不好用,而不会去评价写这个软件的程序员优不优秀. ...

随机推荐

  1. 这个Map你肯定不知道,毕竟存在感确实太低了。

    这是why哥的第 75 篇原创文章 从Dubbo的优雅停机说起 好吧,其实本文并不是讲 Dubbo 的优雅停机的. 只是我在 Dubbo 停机方法 DubboShutdownHook 类中,看到了这样 ...

  2. Markdown文档示例

    目录 我是大标题,和一级标题长得一样 我是次级标题,和二级标题长得一样 这是一级标题 这是二级标题 一直到六级标题 列表 表格 分割线 字体 超链接 插入图片 引用 代码块 注意下面每一个标记如果和内 ...

  3. 目录方式扩展swap分区大小

    1.查看swap大小:free  -m  (-k|m|g) --以k|m|g为单位用去尾法显示大小  [root@lbg tmp]# free -m total        used        ...

  4. Ubuntu12.10 设置默认命令行启动

    在虚拟机当中安装ubuntu12.10的时候默认把图形界面给装上了,由于不需要使用桌面,所以为了省去每次进入到图形界面然后再用ctrl+F1的方式切换到命令行的步骤,希望能够默认进入的是命令行模式,那 ...

  5. deepin 安装最新版node

    安装npm sudo apt install npm 安装node sudo npm install -g n 升级node到稳定版 sudo n stable 升级到最新版 sudo n lates ...

  6. python any,call,init,下划线知识汇总

    python补充 any() [来自菜鸟教程] any() 函数用于判断给定的可迭代参数 iterable 是否全部为 False,则返回 False,如果有一个为 True,则返回 True. 元素 ...

  7. Weblogic CVE-2020-2551漏洞复现&CS实战利用

    Weblogic CVE-2020-2551漏洞复现 Weblogic IIOP 反序列化 漏洞原理 https://www.anquanke.com/post/id/199227#h3-7 http ...

  8. Python:利用Entrez库筛选下载PubMed文献摘要

    一个不是学生物的孩子来搞生物,当真是变成了一块废铁啊,但也是让我体会到了一把生物信息的力量. 废话不多说,开整! 任务:快速高效从PubMed上下载满足条件的文献PMID.标题(TI).摘要(AB). ...

  9. 企业级工作流解决方案(七)--微服务Tcp消息传输模型之消息编解码

    Tcp消息传输主要参照surging来做的,做了部分裁剪和改动,详细参见:https://github.com/dotnetcore/surging Json-rpc没有定义消息如何传输,因此,Jso ...

  10. .NET 5 ORM 八大实用技巧 干货 - SqlSugar ORM

    介绍 sqlsugar已经在第一时间完美兼容.NET5并且已经有人在使用了, 很多人都担心用了开源框架遇到问题无法解决,导致前功尽弃,使用SqlSugar你大可放心,除了有详细文档和几年的大量用户积累 ...