一、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第三次博客作业--第三单元总结的更多相关文章

  1. OO第四次博客作业--第四单元总结及课程总结

    一.总结第四单元两次作业的架构设计 1.1 第一次作业 类图如下: 为了突出类.接口.方法.属性.和参数之间的层次结构关系,我为 Class 和 Interface 和 Operation 分别建立了 ...

  2. [BUAA OO]第三次博客作业

    OO第三次博客作业 1. 规格化设计的发展 我认为,规格化设计主要源自于软件设计的两次危机.第一次是由于大量存在的goto语句,让当时被广泛应用的面向过程式的编程语言臃肿不堪,在逻辑性上与工程规模上鱼 ...

  3. OO第三次博客作业——规格

    OO第三次博客作业——规格 一.调研结果: 规格的历史: 引自博文链接:http://blog.sina.com.cn/s/blog_473d5bba010001x9.html 传统科学的特点是发现世 ...

  4. OO第四次博客作业!

    oo第四次博客作业 一.测试与正确性论证比较 测试只是单方面片面的证明对于当前的输入程序是正确的,测试只能证明程序有错误,不能说明程序是对的. 正确性论证是程序达到预期目的的一般性陈述,是通过规范化的 ...

  5. OO第4次博客作业

    OO第4次博客作业 一.第4单元设计 第四单元主要围绕UML图的结构进行JAVA代码编写,对JAVA的层次结构进行更多的认识.个人认为编程操作在实质上与上一章的PathContainer有许多的相同之 ...

  6. [2017BUAA软工]第三次博客作业:案例分析

    第三次博客作业:案例分析 1. 调研和评测 1.1 BUG及设计缺陷描述 主要测试博客园在手机端上的使用情况. [BUG 01] 不能后退到上一界面(IOS) 重现步骤:打开博客首页中任意博文,点击博 ...

  7. OO第二次博客作业(第二单元总结)

    在我开始写这次博客作业的时候,窗外响起了希望之花,由此联想到乘坐自己写的电梯FROM-3-TO--1下楼洗澡,然后······ 开个玩笑,这么辣鸡的电梯肯定不会投入实际使用的,何况只是一次作业.还是从 ...

  8. OO第四次博客作业(第四单元作业及期末总结)

    (注意:本文写作顺序与作业要求不完全一致,但涵盖了作业的所有要求) 一学期的BUAA特色OO课程结束了. PART 1  我想先写我这一学期的感想 从第一单元满怀期待地写完多项式求值到最后看着60分不 ...

  9. 第三周博客作业<西北师范大学|李晓婷>

    1.助教博客链接:https://www.cnblogs.com/lxt-/MyComments.html 2.学生作业打分要求:   https://www.cnblogs.com/nwnu-dai ...

随机推荐

  1. jquery实现强制刷新

    $('iframe.active').attr('src', $('iframe.active').attr('src'));

  2. python模块--datetime

    datatime.date类 构造器 返回值类型 说明 (year, month, day) date   类方法/属性     .max date datetime.date(9999, 12, 3 ...

  3. LVS+keepalived集群

    一.Keepalived工具介绍专为LVS和HA设计的一款健康检查工具 支持故障自动切换(Failover) 支持节点健康状态检查(Health Checking) 官方网站:http://www.k ...

  4. (6)java Spring Cloud+Spring boot+mybatis企业快速开发架构之SpringCloud-Spring Boot项目详细搭建步骤

    ​ 在 Spring Tools 4 for Eclipse 中依次选择 File->New->Maven Project,然后在出现的界面中按图所示增加相关信息. ​ <paren ...

  5. Linux find命令实例教程 15个find命令用法

    除了在一个目录结构下查找文件这种基本的操作,你还可以用find命令实现一些实用的操作,使你的命令行之旅更加简易.本文将介绍15种无论是于新手还是老鸟都非常有用的Linux find命令.首先,在你的h ...

  6. Docker修改容器中的时间

    Docker修改容器中的时间 前言 在公司开发时使用 Docker 创建数据库(SQL Server)的实例十分方便,还原数据库也只要设置好共享文件夹,在 SQL Server Management ...

  7. Vmware 15 安装 win7 虚拟机 (初学者操作与详解教程)

    @ 目录 一.镜像下载 1.什么是镜像 2.常见的系统镜像文件格式 3.下载win7旗舰版镜像 二.VMware Workstation 下载 1.什么是虚拟机 2.VMware 主要功能 3.VMw ...

  8. 【OI】WERTYU UVa 10082

    题目: A common typing error is to place the hands on the keyboard one row to the right of the correct ...

  9. 利用 Nginx 搭建小型的文件服务器

    利用 Nginx 搭建小型的文件服务器 1.查看 Nginx 配置 android@localhost:/etc/nginx/conf.d$ nginx -hnginx version: nginx/ ...

  10. Python树莓派 爬虫心得

    平台: 树莓派 linux 语言:python 搞一个爬虫都清楚是怎么回事,我这里玩过之后有下面的心得: 为什么要用树莓派呢,省电啊,没乱七八糟的桌面问题,可以一直开着. 1.树莓派上的磁盘写入对于不 ...