Deadline: 2018-09-12 23:00pmhtml
实现一个可以对文本文件文件中的单词的词频进行统计的控制台程序。java
实现一个命令行程序,不妨称之为WordCount。git
输入文件名以命令行参数传入。例如咱们在命令行窗口(cmd)中输入:github
//C语言类 WordCount.exe input.txt //Java语言 java WordCount input.txt
则会统计input.txt中的如下几个指标算法
按照字典序输出到文件result.txt:例如,windows95,windows98和windows2000同时出现时,则先输出windows2000windows
输出的格式为架构
characters: number words: number lines: number <word1>: number <word2>: number ...
在写了一些代码开胃以后,你们都完成了一份知足WordCount基本功能的代码。
你们的代码都各有特点,若是如今咱们要把这个功能放到不一样的环境中去(例如,命令行,Windows图形界面程序,网页程序,手机App),就会碰到困难:代码散落在各个函数中,很难剥离出来做为一个独立的模块运行以知足不一样的需求。
同时咱们也看到,不一样的代码解决不一样层面的问题:框架
这些代码的种类不一样,混杂在一块儿对于后期的维护扩展很不友好,因此它们的组织结构就须要精心的整理和优化。
咱们但愿把基本功能里的:函数
这三个功能独立出来,成为一个独立的模块(class library, DLL, 或其它)。这样的话,命令行和GUI的程序都能使用同一份代码。为了方便起见,咱们称之为计算核心"Core模块",这个模块至少能够在几个地方使用:工具
把计算核心在单元测试框架中作过完备的测试后,咱们就能够在算法层级保证了这个模块的正确性。
但咱们知道软件并不是只有计算核心,实际的软件是交付给最终用户的软件,除了计算核心外,还须要有必定的界面和必要的辅助功能。
这个Core模块和使用它的其余模块之间则要经过必定的API来交流。
API应该怎么设计呢?
为了方便起见,咱们能够从下面的最简单的接口开始(仅举例,你的代码里可能没有这个函数):
int countChar(File *file)
这个函数表示输出一个文件指针,返回这个文件的字符数。
假设咱们用Core封装了这个接口,那么咱们的测试程序能够是这样:
File *in = fopen("input.txt","r"); int count = 100; Assert(countChar(in) == count);
固然,这样的测试程序并不充分,但愿你们测试时不要像这样偷懒。
助教在测试时,将运行自动测试程序编译源文件并运行,进行批量测试,所以请保证项目的组织目录符合要求.
对于使用Java语言的项目有如下两点要求:
一个Java项目的示例组织目录以下所示:
031602111 (文件夹名字为学号) |- src |- Main.java(主程序,能够从命令行接收参数) |- lib.java(包含其它自定义函数,能够有多个,对名字不作要求)
对于使用C++ 语言的项目有如下两点要求:
【以学号为名的文件夹中】的目录下必须有src文件夹,在src文件夹中是可在VS2017下编译运行的解决方案,解决方案的名字必须为 WordCount,一个C++工程示例组织目录以下所示:
031602111 (文件夹名字为学号) |- src |- WordCount.sln |- WordCount |- stdafx.cpp |- stdafx.h |- WordCount.cpp |- WordCount.vcxproj
助教在测试时,将自动按照指定编译环境编译源代码,并利用命令行进行批量测试。
本次自动测试会加入各类各样出错状况的测试,要求开发者程序不能崩溃,而且可以尽量精确报错。你能够有“容错性”的出错设计,但必须输出必要的提示或说明。
PSP是卡耐基梅隆大学(CMU)的专家们针对软件工程师所提出的一套模型:Personal Software Process (PSP, 我的开发流程,或称个体软件过程)。
PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 · Estimate · 估计这个任务须要多少时间 Development 开发 · Analysis · 需求分析 (包括学习新技术) · Design Spec · 生成设计文档 · Design Review · 设计复审 · Coding Standard · 代码规范 (为目前的开发制定合适的规范) · Design · 具体设计 · Coding · 具体编码 · Code Review · 代码复审 · Test · 测试(自我测试,修改代码,提交修改) Reporting 报告 · Test Repor · 测试报告 · Size Measurement · 计算工做量 · Postmortem & Process Improvement Plan · 过后总结, 并提出过程改进计划 合计
一个功能完备的程序不是一蹴而就的。经过将词频统计的需求划分为4个部分,可将一个大任务划分为可操做的小任务,同时最好按照任务难度或紧急程度指定各个任务的完成次序。所以,在动手开发以前,要先估计将在程序各模块开发所需耗费的时间,以及完成整个项目所需的时间,将这个[估计值]记录下来,写成PSP 的形式。
PSP的目的是:记录工程师如何实现需求的效率,和咱们使用项目管理工具(例如微软的Project Professional,或者禅道等)进行项目进度规划相似。
有关PSP的更多内容,请自行阅读邹欣老师的博客:现代软件工程讲义 2 工程师的能力评估和发展
请阅读邹欣老师的博客:源代码管理,了解源代码管理的10个实践问题。
本次做业要求使用Github进行源代码管理,代码有进展即签入Github。签入记录不合理的项目会被助教抽查询问项目细节。
对代码签入的具体要求以下:根据需求划分功能后,每作完一个功能,编译成功后,应至少commit一次。本例中,至少应区分基本功能和扩展功能,即分别针对基本功能、扩展功能,编译成功后,总共至少应commit两次。具体的功能划分,请自行定义,并在撰写博客时体现出来,遵循本身对需求的功能划分来提交代码便可。
对Commit不是很熟悉的话,请阅读阮一峰的博客:Commit message 和 Change log 编写指南,了解更多细节。
请根据本身以往积累的测试经验,在编码完成以后,提交产品以前,设计测试用例,并编写单元测试,对本身的项目进行测试。
首先,至少应采用白盒测试用例设计方法来设计测试用例,其余测试方法不限。其次,要设计至少10个测试用例,确保你的程序可以正确处理各类状况。最后,结合测试评估的要求,对本身的测试设计进行评价,这些测试用例能知足该程序测试的要求吗?
另外一个重要的措施是要把单元测试自动化,这样每一个人都能很容易地运行它,而且可使单元测试天天都运行。每一个人均可以随时在本身的机器上运行。团队通常是在每日构建中运行单元测试的,这样每一个单元测试的错误就能及时被发现并获得修改。
推荐阅读邹欣老师的博客:现代软件工程讲义 2 开发技术 - 单元测试 & 回归测试