OO第三次博客作业--第三单元总结
一、JML 语言的理论基础及应用工具链
JML 是一种行为接口规格语言,提供了对方法和类型的规格定义手段。通过 JML 和其支持工具,不仅可以基于规格自动构造测试用例,并整合了 SMT Solver 等工具以静态方式来检查代码实现对规格的满足情况。
1.1 方法规格
JML 中的前置条件指的是在调用方法之前必须要满足的条件;
后置条件指的是该方法返回时必须要满足的条件,即制定了该方法的指责;
副作用范围限定指的是在执行过程中可能(允许)被修改的对象的属性数据或者类的静态成员变量。
1.2 类型规格
JML 中不变式 (invariant) 是要求在所以可见状态下都必须满足的特性,语法上定义
invariant P,其中invariant为关键词,P为谓词;状态变化约束 (constraint) 是指对象的状态在变化时也需要满足的一些约束,这些约束在本质上也是一种不变式。
1.3 应用工具链
openJML
JMLUnitNG
二、 JMLUnitNG
我使用 JMLUnitNG 组件的流程如下:
下载并安装 JMLUnitNG 组件
使用 JMLUnitNG 生成测试类
在 IDEA 中运行测试类
我首先对一个简单的方法 Demo.java 进行了测试:
通过命令行输入 java -jar jmlunitng.jar Demo.java 生成测试类,然后在测试类目录下建立 project,直接在 IDEA 中运行 Demo_JML_Test 即可。
我生成的测试数据如下:

三、梳理架构设计,分析迭代中对架构的重构
第一次作业

完全按照官方接口建立。
其中 union 记录的是整个 container 中的不同的节点,每次 container 中的路径变化,更新一次 union。
第二次作业

第二次作业将第一次中的 MyPathContainer 部分方法复制到 MyGraph 中,然后根据接口添加了新的方法,其他大致都没变。
第三次作业

第三次作业将第二次作业中的 MyGraph 中部分方法复制过去,然后根据接口添加了新的方法。
这一次作业比上一次添加了很多要求,且复杂度更高了,并且涉及到一些算法上的问题。
我使用的是讨论区大佬的不拆点的算法,用四个数组分别记录、完成四种功能,但其实都是基于最短路径的,只是每种功能中路径的权不同而已。每次更新 Path 时需要更新四个数组,且做四次floyd 。但因为常数较小,所以时间相对较短。
四、分析代码实现的bug和修复情况
第一次作业中,在 MyPath 中实现的 compare 方法中出现了一个小 bug,是我在遇到不相同的节点时,返回的是两值相减的值,这时没有考虑到可能会溢出。修复改为返回两值比较的布尔值。
第二次作业中吸取了第一次作业的教训,认真阅读规格,没有出现Bug。
第三次作业由于比前两次多了很多复杂的逻辑,而我的架构并不适于拓展,慌忙之下写出了一个较为严重的bug。在 containsEdge() 方法中,由于没有认真看规格,将两个同节点算作存在这条边,但实际不应该算作边;另外,在计算 least unpleasant value 时,我的方法需要在每个 path 内部另外计算 path 内节点的 least unpleasant value ,本来可以直接套用计算整个地铁系统的方法,我却另外想了一个更复杂的方法,既添了麻烦又出了错。已经修复为更简单的方法,即将路径权设为 unpleasant value ,然后跑 floyd。
五、对规格撰写和理解上的心得体会
对于一些较为复杂的方法,其规格的逻辑表达式很长,需要认真仔细地阅读,搞清楚前置条件和后置条件。
规格只给出了需要实现的功能,而没有要求如何实现,所以仍需要考虑架构和算法上的设计。
OO第三次博客作业--第三单元总结的更多相关文章
- OO第四次博客作业--第四单元总结及课程总结
一.总结第四单元两次作业的架构设计 1.1 第一次作业 类图如下: 为了突出类.接口.方法.属性.和参数之间的层次结构关系,我为 Class 和 Interface 和 Operation 分别建立了 ...
- [BUAA OO]第三次博客作业
OO第三次博客作业 1. 规格化设计的发展 我认为,规格化设计主要源自于软件设计的两次危机.第一次是由于大量存在的goto语句,让当时被广泛应用的面向过程式的编程语言臃肿不堪,在逻辑性上与工程规模上鱼 ...
- OO第三次博客作业——规格
OO第三次博客作业——规格 一.调研结果: 规格的历史: 引自博文链接:http://blog.sina.com.cn/s/blog_473d5bba010001x9.html 传统科学的特点是发现世 ...
- OO第四次博客作业!
oo第四次博客作业 一.测试与正确性论证比较 测试只是单方面片面的证明对于当前的输入程序是正确的,测试只能证明程序有错误,不能说明程序是对的. 正确性论证是程序达到预期目的的一般性陈述,是通过规范化的 ...
- OO第4次博客作业
OO第4次博客作业 一.第4单元设计 第四单元主要围绕UML图的结构进行JAVA代码编写,对JAVA的层次结构进行更多的认识.个人认为编程操作在实质上与上一章的PathContainer有许多的相同之 ...
- [2017BUAA软工]第三次博客作业:案例分析
第三次博客作业:案例分析 1. 调研和评测 1.1 BUG及设计缺陷描述 主要测试博客园在手机端上的使用情况. [BUG 01] 不能后退到上一界面(IOS) 重现步骤:打开博客首页中任意博文,点击博 ...
- OO第二次博客作业(第二单元总结)
在我开始写这次博客作业的时候,窗外响起了希望之花,由此联想到乘坐自己写的电梯FROM-3-TO--1下楼洗澡,然后······ 开个玩笑,这么辣鸡的电梯肯定不会投入实际使用的,何况只是一次作业.还是从 ...
- OO第四次博客作业(第四单元作业及期末总结)
(注意:本文写作顺序与作业要求不完全一致,但涵盖了作业的所有要求) 一学期的BUAA特色OO课程结束了. PART 1 我想先写我这一学期的感想 从第一单元满怀期待地写完多项式求值到最后看着60分不 ...
- 第三周博客作业<西北师范大学|李晓婷>
1.助教博客链接:https://www.cnblogs.com/lxt-/MyComments.html 2.学生作业打分要求: https://www.cnblogs.com/nwnu-dai ...
随机推荐
- jquery实现强制刷新
$('iframe.active').attr('src', $('iframe.active').attr('src'));
- python模块--datetime
datatime.date类 构造器 返回值类型 说明 (year, month, day) date 类方法/属性 .max date datetime.date(9999, 12, 3 ...
- LVS+keepalived集群
一.Keepalived工具介绍专为LVS和HA设计的一款健康检查工具 支持故障自动切换(Failover) 支持节点健康状态检查(Health Checking) 官方网站:http://www.k ...
- (6)java Spring Cloud+Spring boot+mybatis企业快速开发架构之SpringCloud-Spring Boot项目详细搭建步骤
在 Spring Tools 4 for Eclipse 中依次选择 File->New->Maven Project,然后在出现的界面中按图所示增加相关信息. <paren ...
- Linux find命令实例教程 15个find命令用法
除了在一个目录结构下查找文件这种基本的操作,你还可以用find命令实现一些实用的操作,使你的命令行之旅更加简易.本文将介绍15种无论是于新手还是老鸟都非常有用的Linux find命令.首先,在你的h ...
- Docker修改容器中的时间
Docker修改容器中的时间 前言 在公司开发时使用 Docker 创建数据库(SQL Server)的实例十分方便,还原数据库也只要设置好共享文件夹,在 SQL Server Management ...
- Vmware 15 安装 win7 虚拟机 (初学者操作与详解教程)
@ 目录 一.镜像下载 1.什么是镜像 2.常见的系统镜像文件格式 3.下载win7旗舰版镜像 二.VMware Workstation 下载 1.什么是虚拟机 2.VMware 主要功能 3.VMw ...
- 【OI】WERTYU UVa 10082
题目: A common typing error is to place the hands on the keyboard one row to the right of the correct ...
- 利用 Nginx 搭建小型的文件服务器
利用 Nginx 搭建小型的文件服务器 1.查看 Nginx 配置 android@localhost:/etc/nginx/conf.d$ nginx -hnginx version: nginx/ ...
- Python树莓派 爬虫心得
平台: 树莓派 linux 语言:python 搞一个爬虫都清楚是怎么回事,我这里玩过之后有下面的心得: 为什么要用树莓派呢,省电啊,没乱七八糟的桌面问题,可以一直开着. 1.树莓派上的磁盘写入对于不 ...