第一次个人编程作业

Posted Freyr_S

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第一次个人编程作业相关的知识,希望对你有一定的参考价值。

https://github.com/Freyr-S/Sensitive-Word-Filtering

一、PSP表格

  • (2.1)在开始实现程序之前,在附录提供PSP表格记录下你估计将在程序的各个模块的开发上耗费的时间。(3\')
  • (2.2)在你实现完程序之后,在附录提供的PSP表格记录下你在程序的各个模块的开发上实际花费的时间。(3\')
PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)
Planning 计划
· Estimate · 估计这个任务需要多少时间 30
Development 开发
· Analysis · 需求分析 (包括学习新技术) 350 650
· Design Spec · 生成设计文档 20
· Design Review · 设计复审 15
· Coding Standard · 代码规范 (为目前的开发制定合适的规范) 5
· Design · 具体设计 100
· Coding · 具体编码 500
· Code Review · 代码复审 120
· Test · 测试(自我测试,修改代码,提交修改) 120
Reporting 报告
· Test Repor · 测试报告 130
· Size Measurement · 计算工作量 50
· Postmortem & Process Improvement Plan · 事后总结, 并提出过程改进计划 30
· 合计 1470

二、计算模块接口

  • (3.1)计算模块接口的设计与实现过程。设计包括代码如何组织,比如会有几个类,几个函数,他们之间关系如何,关键函数是否需要画出流程图?说明你的算法的关键(不必列出源代码),以及独到之处。(18\')
    算法:ac自动机
    算法的关键:一、字典树的构建过程;二、找Fail指针;三、文本串的匹配

    类:
    Node:叶节点
    BuildAc:用于构建ac自动机的Tire树
    函数:
    get_pinyin():将汉字转换为拼音
    sim2tradition():将简体字转换为繁体字
    tradition2sim():将繁体字转换为简体字
    get_initial():获得词的首字母
    sensitive_word():生成所有的需检测出的词
    add_word():添加敏感词
    make_fail():生成失败指针
    search():查找敏感词

  • (3.2)计算模块接口部分的性能改进。记录在改进计算模块性能上所花费的时间,描述你改进的思路,并展示一张性能分析图(由VS 2019、JProfiler或者Jetbrains系列IDE自带的Profiler的性能分析工具自动生成),并展示你程序中消耗最大的函数。(12\')

  • (3.3)计算模块部分单元测试展示。展示出项目部分单元测试代码,并说明测试的函数,构造测试数据的思路。并将单元测试得到的测试覆盖率截图,发表在博客中。(12\')

  • (3.4)计算模块部分异常处理说明。在博客中详细介绍每种异常的设计目标。每种异常都要选择一个单元测试样例发布在博客中,并指明错误对应的场景。(6\')

三、心得

  • (4.1)在完成本次作业过程的心得体会(3\')

    虽然没有完成,但学到了很多以前不会的,受益匪浅,很开心。
    这次磨时间拖太久了,写了个寂寞,以后要尽早规划作业,多学习多练习

以上是关于第一次个人编程作业的主要内容,如果未能解决你的问题,请参考以下文章

第一次个人编程作业

结对编程第一次作业

结对编程第一次作业

第一次个人编程作业

软件工程(2018)结对编程第一次作业

软件工程(2018)结对编程第一次作业