Github项目地址 | Github地址 |
---|---|
结对伙伴 | 黄天兵201831061126的博客 |
①代码结构:
程序由一个 wordsCount 类, main() 主函数和 Getop(string cmd) 获取命令参数函数构成。其中 wordCount 类成员中含 Char_num() 、 Lines_num() 等函数。思惟导图以下:
②.关键函数实现:
int wordsCount::Char_num() :获取ascii数html
获取输入文件路径后,经过对文件内容逐个读取,并只对ASCII码进行计数。git
int wordsCount::Lines_num():获取文件行数github
使用 getline() 函数获取文件的每一行对行数进行计数。编程
void wordsCount::GetWords()、int wordsCount::Words_num() 、void wordsCount::Sort_words_rate()ide
因为对单词时有额外的要求:单词计数,按照出现频率和字典排序,以小写输出。因此使用多个函数实现:
(1) void wordsCount::GetWords() :逐个读取文件字符,将全部符合要求的“单词”提取出来,转为小写形式后(使用 algorithm 头文件中的 transform() 函数 ),存放在一个 vector< string > 容器中。
(2) void wordsCount::Sort_words_rate():对于统计词频首先想到的是用 pair<string , int> 记录词频,排序则使用algorithm头文件下的 sort() 函数。因而乎为了方便统计词频,先排序,使相同的单词在一起,再统计词频,统计好的词频存放在 vector<pair<string , int>> 中,再对其词频进行排序。(sort()函数中第三个参数提供了自定义排序标准)
__main(int argc, char *argv[])__ :主函数函数
main()函数主要接受用户从操做系统传入的参数,参数经过Getop()函数解析后执行不一样的输出。性能
③.编程思想体现
Interface Design:单元测试
对于接口的设计,咱们将wordCount这个类中全部属性和成员函数的定义与实现分开测试
Information Hiding:ui
信息隐藏,简单地说就是是否可见是否与可用。
不可见不可用:
咱们将类的属性和成员定义放在wordCount.h的头文件中,实现部分放在wordCount.cpp中,使类中内容对外部而全然隐藏。
可见不可用:
经过使用private、protect对类中成员和属性进行修饰。包含头文件后,即便能看到这些属性,却没法使用它们
④效果展现
①编码规范:
咱们采用的是Google的C++编码规范
中文版
Google C++编码规范
②复审过程:
Vs2017具有强大的努力的复审功能,能够进行智能缩进,大大提升了规范性。vs2017是真的功能强大。
根据参考文献咱们对代码稍微作改动,使它陷入循环,VS2017自带的“性能探查器"真的好用
性能分析报告:
单元测试参考文献Part3
①出现问题:在按照上面文献的步骤流程作完之后,发现测试仍是没有经过
②解决问题:测试代码也确定没有问题。通过不断的摸索,发现原来是测试用的文件应该放在这里头
③总结:测试中的待打开的文件不能与代码放在一块儿,须要放在与后缀为“.exe”相同的路径下。
④测试结果:因为水平有限,只测试了几个函数,而且通过长时间摸索仍是解决了问题。经过了测试。
测试的几个函数:Char_num(),int Lines_num(),int Words_num();终于仍是经过了测试
1.抛出异常:
·文件打开失败:
·用户未输入参数、参数个数错误、参数不包含“-i”和“-o”:
·检查“-n”和“-m”后面的参数是否为数字:
在程序中使用了stoi()函数实现字符串转整型,若转换失败则会自动抛出异常。
2.捕获异常:
使用try-catch对异常进行捕获
3.测试结果:
①错误输入
②正确输入
①感觉:
我和我室友黄天兵同窗进行结对编程,两我的相互讨论的模式其实之前也有用到,不过此次的更加全面完善,咱们确实感受到了1+1>2的效果。队友的代码量大大高于我,能力也强。我更多的时间花在了代码的单元测试上。可是经过此次结对编程确实也感受到了本身和大佬的差距,也复习了之前没搞清楚的有关字符的知识点。伙伴的坚持精神也深深感染了我。仍是那句老话“革命还未成功,同志还需努力。最后感谢”
②照片: