结对编程项目(除附加题)开发过程

结对编程项目(除附加题)开发过程

结对同伴:李云涛

一、照片

结对同伴在家,等回校后补上。

二、结对编程评价

优点:

1、两个人的编程思想、算法、代码风格可以互相借鉴和学习,对于两人的编程水平的提高都很有帮助。

2、两个人可以分工写不同的相对独立的模块,加快开发的进度。

3、自己程序的bug可能自己怎么找都找不到,而自己的同伴就能很快找到。

缺点:

有些工作必须得两人在一起才能进行,而两人都空闲的时间不是太多,很多时候需要通过线上进行交流,导致工作被耽搁。

我自己的优点:做事认真、有恒心、有学习精神。

我自己的缺点:编码风格较差。

对方的优点:编码能力很强、专业功底扎实、提的建议很中肯。

对方的缺点:比较忙、有时抽不出时间做结对项目。

三、信息隐藏、接口设计、松耦合设计方法的使用

这三种设计方法其实本质是同一个:将属于自己类或者模块维护的信息通过私有属性保护起来,对外不可见,对这些数据的操作和维护由本模块独立完成。为了让外部的功能模块使用本模块的服务,就通过提供给外部一组规范化的函数调用接口来实现,外部模块只需要了解每个函数或方法的原型及其规格,就可以正确地使用这些服务。这样达到的好处是:每一个模块彼此之间的功能是独立的,它们内部的实现不依赖与外部模块,也即是说,不同人写的相同功能的模块应该是可以互相替代的。

这三种思想其实都是面向对象思想的体现。

就我们编程而言:核心模块、测试模块、用户界面模块是三个功能完全独立的模块,因此,我们完全可以将这三个模块独立开发,由核心模块提供给测试模块和用户界面模块一定的接口,两者只需要输入参数(generate、check、calc三者选其一),就可以调用核心模块的相应代码来执行。如果后期要对用户界面进行优化,那么只需要更改用户界面模块即可,大大减小了维护的工作量。

四、契约式编程

契约式设计(英语:Design by Contract,缩写为 DbC),一种设计计算机软件的方法。这种方法要求软件设计者为软件组件定义正式的,精确的并且可验证的接口,这样,为传统的抽象数据类型又增加了先验条件、后验条件和不变式。这种方法的名字里用到的“契约”或者说“契约”是一种比喻,因为它和商业契约的情况有点类似。(转自维基百科)

我的理解:所谓契约式编程,就是模块使用者和模块实现者遵守一个共同的约定:模块使用者保证传给模块实现者的参数是符合模块实现者的方法的前置条件的,模块实现者保证在前置条件得以满足的情况之下,传回给模块调用者的参数是符合后置条件的,并且,如果在方法执行过程中改变了某些外部变量,必须让模块调用者显示知晓。

这种编程设计的优点是调用者无需关心实现者的实现细节,只需了解给出的规格就可以正确使用每一个方法,比如我们用java写程序,String类的每一个方法都会给出这个方法的原型以及简单的说明,我们不知道java源代码是如何实现这些方法的,但是这完全不妨碍我们正常使用。同样地,对于模块调用者而言,他也无需关心调用者会如何使用自己的方法,他只需要专注于实现规格规定的功能即可。这样带来的好处是程序各个模块之间的独立性增强,更加利于维护和扩展。

这种方法的坏处则是如果有一方没有遵守契约,那么可能会带来严重的后果,比如调用者传入的数据不符合前置条件,而实现者又没有进行检查,而错误又在代码执行了很久之后才出现,那么排查的工作量将是巨大的。

很遗憾,我们此次作业没有使用这样一个设计(时间比较紧),争取在下一个项目得以改正。

五、单元测试

以我们写的一个BasicNum类为例,该类有三个方法:floatCmp、gcd、power,我们写了一个测试文件BasicNumTests,分别测试这三个方法,截图如下:

由截图可知,三个方法测试通过,且该类的代码覆盖率为100%。

六、UML序列图

七、算法关键

我们要实现三个功能:自己生成算式自己计算,检查别人的算式是否计算正确,计算一个算式的结果。因此,我们抽象出了这几个独立的功能模块:生成算式模块、计算模块、输入输出模块、读算式分析模块。其中,生成算式模块通过随机函数随机生成各种数字、运算符和括号,并且调用读算式分析模块将中缀表达式转换成后缀表达式,计算模块读入后缀表达式算出结果,如果结果合法(非负且不被0除),那么记录下这个算式和答案,返回生成算式模块生成下一个算式,如果不合法则重新生成。这是对于自己生成算式自己计算这一功能。对于检查别人的算式和结果,只需要读入算式进行分析,计算出结果,与答案比对即可。对于纯计算模块,则直接调用分析模块和计算模块即可。输入输出模块完成与其他模块的传参交互工作。

一个细节:由于要支持分数,所以我们的所有数据全部用一个Number类型来表示,由于所有的输入输出数据都是有理数,我们全部转换成分数来处理,重置了分数下的四则运算和关系运算符,最后结果根据需要用分数或者小数表示,这样就不会因为浮点数运算而带来精度损失。

八、总结

第一次结对编程项目,把一个看似很简单的程序封装成一个可用的软件,其中遇到了很多很多的问题,比如测试文件怎么写?UI怎么写?C#的语法不是很熟悉等等,也因为不熟悉VS2015的编程环境而忙活了好半天,不过最后做出来的软件尽管青涩生疏,毕竟是麻雀虽小五脏俱全,能自己独立开发一款软件,还是很有成就感的。

时间: 2024-10-24 23:22:58

结对编程项目(除附加题)开发过程的相关文章

结对项目(附加题)开发总结

结对项目(附加题)开发总结 这次附加题的任务就是把两个小组写的独立的UI和CORE模块打乱重组,拼接成一个新的APP. 我们小组选择了大神刘乾所在小组和我们合作交换.一拿到乾神的核心代码,我不得不说,乾神就是乾神,代码一出,直接把我镇住了,各种参数看不懂咋办?咋写UI? 还好我们的乾神同志给我们提供了帮助文档,介绍了各个参数的作用,现摘录如下: 对于计算表达式的值(CALC模式): AnswerGet(string s)其中s是给定的算式,以等号结尾. 调用生成器时,使用: public Gen

结对编程项目复盘:带UI的小初高数学学习软件

实现个人项目时,由于我当时的Java GUI编程基础还比较薄弱,所以我选择通过命令行实现,并将编程开发的重点放到了算法效率上去.没能设计出用户体验更佳的UI成为了我在个人项目阶段最大的遗憾. 在这次结对编程项目时,有幸能和擅长图形化编程的志豪同学结为队友.他在SIT项目中所学习到的GUI编程方法与我在CCF与ACM训练中积累到的一些算法经验相得益彰,所以在编程项目已经结束的现在,我认为并相信,我们都学到了很多. 经过讨论,我们在一开始便将项目分为四个部分:短信验证码功能实现.UI界面实现.出题功

20165206 结对编程项目-四则运算 阶段一总结

20165206 结对编程项目-四则运算 阶段一总结 一.需求分析 通过命令行输入生成题目的数量,随机生成题目. 生成的题目不重复. 生成的四则运算题目支持整数.支持多运算符. 能够根据作答情况统计正确的个数. 二.设计思路 设计一个类来实现整数的四则运算. 用一个循环结构来生成随机数,生成题目. 设计一个类来比较输入的答案与正确答案是否一致. 判断做的题是否正确,并返回正确的个数. 设计单元测试,对代码进行测试及修改 UML图: 三.核心代码 生成随机数: while(true){ a=new

20165318 结对编程项目-四则运算 阶段总结

20165318 结对编程项目-四则运算 阶段总结 一.需求分析 能随机生成n道四则运算题目,n由使用者输入 支持整数和分数 支持多运算符 能够判断正误,错误时能提醒并输出正确答案 能计算出正确率 能多次生成题目,直到使用者选择退出 后续拓展的可能 题目去重 文件: 处理生成题目并输出到文件 完成题目后从文件读入并判题 多语言支持:简体中文, 繁體中文, English 二.设计思路(同时输出UML类图) 首先考虑生成题目. 随机生成题目,用到Random函数,生成题目应该是同时随机生成数字和四

20165230 结对编程项目-四则运算 整体总结

20165230 结对编程项目-四则运算 整体总结 一.需求分析 随机生成题目 生成的题目个数从命令行输入 用户可选择生成不同难度的题目,比如通过参数指定: (1) 运算符个数范围 (2) 运算符限定(小学一年级题目只生成 + - 题目) 能多次生成题目 题目运算(判题) 支持多运算符 支持整数 支持真分数 题目合法性判断 可独立使用 可用于测试生成题目的正确性 扩展需求 题目去重 支持多语言 处理生成题目并输出到文件 完成题目后从文件读入并判题 二.设计思路 设计一个IntNumber类,用来

20165330 结对编程项目-四则运算 第二周

需求分析 实现一个命令行程序,要求:自动生成小学四则运算题目(加.减.乘.除) 可实现多个运算符一起运算 可以真分数形式输出结果 测试结果的正确性 统计题目完成数并计算正确率 设计思路 实验首先是完成一个计算器的功能,可以实现简单的+.-.*./运算,在这里设计一个主类生成随机数,生成题目,并判断正确率 实现多运算符,编入四个类分别实现整数运算.真分数运算.判断结果正确并计算正确率 利用JUnit检测非法输入 设计测试类,利用JUnit测试整数类与分数类的四则运算 UML类图 功能截图 Juni

结对编程项目——收获及感想

结对编程项目-带UI的小初高数学学习软件 一.项目需求 用户: 小学.初中和高中学生. 功能: 1.用户注册功能.用户提供手机号码,点击注册将收到一个注册码,用户可使用该注册码完成注册: 2.用户完成注册后,界面提示设置密码,用户输入两次密码匹配后设置密码成功.密码6-10位,必须含大小写字母和数字: 3.密码设置成功后,跳转到选择界面,界面显示小学.初中和高中三个选项,用户点击其中之一后,提示用户输入需要生成的题目数量: 4.用户输入题目数量后,生成一张试卷(同一张卷子不能有相同题目),界面显

20175212童皓桢 结对编程项目-四则运算 第一周

20175212童皓桢 结对编程项目-四则运算 第一周 需求分析 实现一个命令行程序,要求自动生成小学四则运算题目(加减乘除) 支持多运算符 测试结果的正确性,用户输入错误时给出正解 统计题目正确率 设计思路 首先要能够按照按人的一般习惯,生成自左向右计算的加减乘除算式. 随机生成多运算符,并随机生成相对应个数的整数 利用eval方法直接计算随机生成的算式的值,并和用户的输入作比较 判断正确率 设计测试类,利用JUnit测试整数的四则运算 UML类图 关键代码 如何生成符合要求格式的运算式 fo

20175209王梓鸿 结对编程项目—四则运算 第一周 阶段总结

20175209王梓鸿 结对编程项目-四则运算 第一周 阶段总结 一.需求分析 1.题目要求: 实现一个命令行程序,要求: 自动生成小学四则运算题目(加.减.乘.除) 支持整数 支持多运算符(比如生成包含100个运算符的题目) 支持真分数 统计正确率 扩展需求 文件 处理生成题目并输出到文件 完成题目后从文件读入并判题 多语言支持简体中文,繁體中文,English 生成题目去重 二.设计思路 1.编写背景及完成情况 在开始写设计思路之前,我觉得应该说一下我们编写的情况(可能有些跑题).这次结对的