1)在文章开头给出Coding.Net项目地址。(1')
https://git.coding.net/meiyoupiqidefan/jieduizuoye.git
url测试地址:http://39.105.6.214/four_Operations
2)在开始实现程序之前,在下述PSP表格记录下你估计将在程序的各个模块的开发上耗费的时间。(1’)
PSP
PSP |
任务内容 |
计划共完成需要的时间(min) |
实际完成需要的时间(min) |
Planning |
计划 |
10 |
|
Estimate |
估计这个任务需要多少时间,并规划大致工作步骤 |
5 |
|
Development |
开发 |
5*60 |
|
Analysis |
需求分析 (包括学习新技术) |
10*60 |
|
Design Spec |
生成设计文档 |
1*60 |
|
Design Review |
设计复审 (和同事审核设计文档) |
20 |
|
Coding Standard |
代码规范 (为目前的开发制定合适的规范) |
10 |
|
Design |
具体设计 |
30 |
|
Coding |
具体编码 |
20*60 |
|
Code Review |
代码复审 |
3*60 |
|
Test |
测试(自我测试,修改代码,提交修改) |
5*60 |
|
Reporting |
报告 |
2*60 |
|
Test Report |
测试报告 |
3*60 |
|
Size Measurement |
计算工作量 |
20 |
|
Postmortem & Process Improvement Plan |
事后总结, 并提出过程改进计划 |
30 |
3)看教科书和其它资料中关于Information Hiding, Interface Design, Loose Coupling的章节,说明你们在结对编程中是如何利用这些方法对接口进行设计的。(3')
Information Hiding信息隐藏:
什么是信息隐藏:
信息隐藏指在设计和确定模块时,使得一个模块内包含的特定信息(过程或数据),对于不需要这些信息的其他模块来说,是不可访问的。
为什么要信息隐藏:
- 隐藏复杂度:这样你就不用再去应付它,除非你要特别关注的时候;
- 隐藏变化源:这样当变化发生时,其影响就能被限制在局部范围内。复杂度的根源包括复杂的数据类型、文件结构、布尔判断以及晦涩的算法等等。
我们是怎么做的:
把方法集中到一个接口里,同时利用多态,使方法更易更改,代码重写性强。
Interface Design接口设计:
什么是接口设计:对接口的名字,功能,接口与接口间的继承关系进行设计;
为什么要接口设计:好的接口设计可以增强代码可读性,易用性,可更改性
我们是怎么做的:设计接口,规范接口名字,注重接口逻辑。
Loose Coupling 松耦合:
什么是松耦合:也叫做弱耦合,低耦合。耦合性也称块间联系。指软件系统结构中各模块间相互联系紧密程度的一种度量。模块之间联系越紧密,其耦合性就越强,模块的独立性则越差。模块间耦合高低取决于模块间接口的复杂性、调用的方式及传递的信息。
什么要松耦合:功能上或代码上可以达到重用,再组合新功能的时候,可以像搭积木一样,分别拿出去再重用,而不会太关联其他。
我们是怎么做的:将相互依赖的类放在一个命名空间(包)中,对外模块尽量与其他方法或功能减少联系。
4)计算模块接口的设计与实现过程。设计包括代码如何组织,比如会有几个类,几个函数,他们之间关系如何,关键函数是否需要画出流程图?说明你的算法的关键(不必列出源代码),以及独到之处。(4')
算法的话,一共在src层写了三个包:util、control、entiity
entity包中装javabean通过List泛型进行传输题目有关的信息,并按一次一题的形式呈现在前台界面;
control包中装有用来处理各种请求的Servlet文件;
util包中装有各种处理类,比如读取服务器端文件并进行下载的类等等;
关键函数是Generate类中的生成算法和Command类中的计算算法;
达到功能的模块化,核心模块是显示题到servlet界面的反复逻辑跳转;
5) 计算模块接口部分的性能改进。记录在改进计算模块性能上所花费的时间,描述你改进的思路,并展示一张性能分析图,并展示你程序中消耗最大的函数。(4')
6)计算模块部分单元测试展示。展示出项目部分单元测试代码,并说明测试的函数,构造测试数据的思路。并将单元测试得到的测试覆盖率截图,发表在博客中。只需要测试命令行部分,且该部分覆盖率到90%以上,否则单元测试部分视作无效。(6')
7)计算模块部分异常处理说明。在博客中详细介绍每种异常的设计目标。每种异常都要选择一个单元测试样例发布在博客中,并指明错误对应的场景。(5')
我们制作的是web端四则运算器,在网页的输入中,我们使用了Bootstrap Validate 插件,对于不合法的值显示红框提示,合法的数值予以绿框通过,在前台保证传入到后台的值全部合法且有效。
部分代码如下:
8)界面模块的详细设计过程。在博客中详细介绍界面模块是的,并写一些必要的代码说明解释实现过程。(5')
下图为流程图:
9)界面模块与计算模块的对接。详细地描述UI模块的设计与两个模块的对接,并在博客中截图实现的功能。(4')
index.jsp
主界面,可以选择出题还是做题;
setQuestions.jsp 出题界面,输入参数,定制题目
利用我们团队书写的js实现:只要输入为空即会提示并不访问服务器资源;
点击出题之后,可以浏览器下载出好的题目:
接下去是做题界面
upload.jsp 先从本地上传文件到服务器
服务器接收数据并显示出来:
在答案框输入错误格式文件或者错误内容时会出现提示:
若如下上传不合法内容:
则会显示:
10)描述结对的过程,提供非摆拍的两人在讨论的结对照片。(1')
11)结对编程的优缺点和结对成员的优缺点
结对编程:
优点:
- 两个人思维互补,互相讨论,有助于解决问题。
- 在有另一个人在场的情况下,给了编码者一定的压力,使得效率更高,互相监督,互相促进。
- 增强代码的可靠性,增强代码和产品质量,减少bug。
缺点:需要互相配合时间,习惯。
我:
优点:
- 思路清晰,规划项目
- 认真细致,遇到问题,耐心调试
- 编码速度较快
缺点:没有写注释的习惯,不太能听取或者不太能听懂搭档的意见;
我的搭档:
优点:
- 比较细心,在我逻辑盲区的时候真的能为我提供一些快捷又省力的方法;
- 代码逻辑强,善于优化代码
缺点:
和我一样都太能玩了呜呼呼呼,清明全都出去玩了,这两天没日没夜地赶项目呜呜呜;
12)在你实现完程序之后,在附录提供的PSP表格记录下你在程序的各个模块上实际花费的时间。(1')
PSP
PSP |
任务内容 |
计划共完成需要的时间(min) |
实际完成需要的时间(min) |
Planning |
计划 |
10 |
15 |
Estimate |
估计这个任务需要多少时间,并规划大致工作步骤 |
5 |
30 |
Development |
开发 |
5*60 |
3*60 |
Analysis |
需求分析 (包括学习新技术) |
10*60 |
10*60 |
Design Spec |
生成设计文档 |
1*60 |
1*60 |
Design Review |
设计复审 (和同事审核设计文档) |
20 |
30 |
Coding Standard |
代码规范 (为目前的开发制定合适的规范) |
10 |
15 |
Design |
具体设计 |
30 |
1*60 |
Coding |
具体编码 |
20*60 |
24*60 |
Code Review |
代码复审 |
3*60 |
5*60 |
Test |
测试(自我测试,修改代码,提交修改) |
5*60 |
2*60 |
Reporting |
报告 |
2*60 |
1*60 |
Test Report |
测试报告 |
3*60 |
1*60 |
Size Measurement |
计算工作量 |
20 |
20 |
Postmortem & Process Improvement Plan |
事后总结, 并提出过程改进计划 |
30 |
30 |