zoukankan      html  css  js  c++  java
  • 个人项目之词频统计

    写在前面

    这大概算是我第一次写博客。主要是对软件工程的第一次个人项目作一下总结,项目的具体要求见http://www.cnblogs.com/jiel/p/3978727.html

    总的来说这次作业做的很虐心,但是能够总结点经验也算是对得起我前几天耗在这上面的时间。如果有错误,希望大家提出来,多多交流 ^-^

    项目时间预估

    开发环境的搭建    2h

    项目需求分析       1h

    编写代码              6h

    软件测试及调试    1h

    性能分析与优化    2h

    (ps:  一共12h,一天就可以搞定的样子,理想是如此的丰满!!木心先生的友人评价他是”一个很好的悲观主义者“,不知道我算不算得上是一个很不好的乐观主义者?)

    项目实际用时

    开发环境的搭建     2h+2h=  4h    

    项目需求分析        1h                                

    编写代码               6h+6h=  12h 

    软件测试及调试     1h+2h=  3h

    性能分析与优化     2h+3h=  5h

    (ps: 开发环境搭建我其实用了一晚上,先是把VS2010给卸了,再安装VS2012我走了点弯路,居然把安装包给下载错了,导致我安装了两次

           需求分析是英文的,感觉老师用英文写也算是用心良苦,可能有的说法英文表述会更清楚。但是我会说我是直接用的谷歌翻译吗?!下次绝对要好好读英文O_O 其实编写程序的时候看需求分析可能看得更多,零零碎碎的时间不太好统计,大概也就总共1小时吧。

      编写代码!!!其实我一开始听到这个作业就想起了OO课,本来以为可以借鉴之前Java写的程序,可是实际情况是我用的C#并且整个代码体系和之前的程序完全不像。其实程序的思路还算是比较简单的:递归找出目录下的所有符合条件的文本文件,然后把所有文本文件的内容都读入到一个字符串,对这个字符串进行解析,统计出现次数,最后对单词进行排序输出。不过我每一项都摸索了好久,~~o(>_<)o ~~  拿对字符串进行解析为例,我是先想着要用正则表达式,后来发现我不太会用,然后打算一五一十地一个个字符进行判断,发现工程量有点浩大,最后在网上查到了一个很有效的方法——利用状态机的思想。我看懂了之后真的觉得很高兴,之前学的计组知识终于发光发热了啊,然后这个就导致我后面的扩展模式写的很快。总的来说,上手很艰难,但是写到后半段就会好很多。

      软件测试及调试,这方面对各种异常也没有进行处理,只是处理了目录不存在的情况= =我果然是很懒,不知道老师说得正确性分析会不会包含异常情况,有的话我必跪无疑。至于为什么用了5h(估计不止),我觉得是我对于测试用例考虑的还很不周全。总是发现了一种错误,然后去调试,完了又是另一种错误,反正每次改正错误的效率很低。另外关于字典序和ASCALL这方面也纠结了很久。

      性能分析与优化这方面花的时间主要是前半段对优化工具的学习上。老师给的那个网址我去看了,而且看了好久,可悲的没看出什么门道来,我的英文水平啊!不过最后我也就是按了下”启动性能测试“,然后各种图、各种分析都出来了,不得不说微软出的东西很强大。)

    性能优化

    从进行性能测试,然后改代码进行优化,前后大概花了3,4个小时吧。

    优化之前,我用 ”F:文档“ 进行测试,用了大概5分钟,直接上图

    然后具体一看发现是我那个字符串拼接用得太多了

    然后就想着要怎么优化,我紧接着又犯了一次错误:改成了通过不断调用一个函数来一个文件一个文件地进行解析,没想到时间居然变成了350s,这时候才意识到函数的不断调用远比字符串拼接更费事好吗。。。然后继续改,发现ReadLine()其实可以换成ReadToEnd(),再次运行,时间变成12s了

    优化后的~

    测试用例

    1目录不存在

    2目录下为空

    下面是一些自己构造的文本文件

    3测试单词合并

      file filE  

      期待输出:filE:2

    4测试无效单词的排除

      file 123file

      期待输出:file:1

    5.测试排序输出的顺序 file aaa File aaa  bbb

      期待输出:File:2

           aaa:2

           bbb:1       

    6.测试两个单词的输出

    7测试3个单词的输出

    8目录下包含有汉字的文本文件 乱码

    9目录下一个比较大的文本文件

    10目录下n多文件,包含其他后缀名

    (在这里真诚地向老师提一点建议:关于”programs with incorrect result will get 0 points,  regardless of speed“,程序不正确,得分直接为0,如何定义不正确呢?检查用的10个用例里有2个测得不正确和10个都不正确,得分同样为0的话似乎有点不公平吧。)

    关于收获

    说实话写完这个作业,我觉得挺不容易的。我的coding能力比较弱,我一直都很清楚,没办法在几个小时内快速写出代码来。我在msdn库上查函数,也要比较好久才能选定用哪一个。其实说到底还是因为写得不够。事实就是如此,那些大神在代码上花的时间绝对不少。这世界上的天才哪能那么多呢。其实整个过程,特别是在前期,挺痛苦的,宿舍里就我一个需要写这个,想要交流下甚至找不到人,只能在网上各种查资料。然后对着电脑真的很无奈,我是很想出去随便走走的,只是看看天也好,最后还是在寝室里窝着写代码。。。好了,够了。下面是正式的总结,前面的助教就跳过吧~~

    1.一些文件操作函数的使用。之前递归目录的时候一直是自己写函数,现在发现可以直接用GetFiles,直接可以提取文件了,很方便

    2.cmd模式下运行程序,其实我是第一次体验这个,之前的命令行也是直接设置的,这次运行cmd试了下,感觉挺新奇的

    3.用状态机的思想对字符串进行解析

    4.C#的一些语句的用法。比如orderby可以很方便地实现排序

    嗯,上面的几点其实都是关于具体的程序代码方面的收获。往大的方向说,或许也能包括独立完成一个项目,权衡项目进度,熟悉项目流程等方面能力的提升吧。

    (还有,我写这个博客写了快3个小时了,,这速度)

    最后

    茨威格写断头皇后玛丽·安托瓦内特的一句话:

    她那时候还太年轻,不知道所有命运赠送的礼物,早已在暗中标好了价格。

  • 相关阅读:
    漂亮灵活设置的jquery通知提示插件toastr
    C# 对List<T>取交集、连集及差集
    查看sqlserver被锁的表以及如何解锁.
    javascript的setTimeout()用法总结,js的setTimeout()方法
    日志插件 log4net 的使用
    Log4NET简介
    解决WCF大数据量传输 ,System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接
    也说Autofac在MVC的简单实践:破解在Controller构造函数中的实例化
    Autofac 依赖注入 ASP.NET MVC5 插件机制中插件的简单实现
    Asp.net mvc中整合autofac
  • 原文地址:https://www.cnblogs.com/encoin/p/3986547.html
Copyright © 2011-2022 走看看