软件构造笔记——specification

一:规约的引出:行为等价性

1.行为等价性

行为对等的的概念是客户眼中的,为了能够用一种实现代替另一种实现,并知道什么时候可以接受,因此java中需要一个规范来说明客户端所依赖的内容-specification。

2.例子

在这里插入图片描述

3.分析

函数一正向查找,直到找到val,返回位置i;否则,返回数组长度
函数二倒向查找,直到找到val,返回位置i;否则,返回-1
可以看出此二者不同,那么是否具有行为等价性呢,这需要从客户端及用户的视角查看
由此引出规约。
设两者规约为:
在这里插入图片描述

对于用户而言,使用两函数的requires为val只在数组中出现一次且必出现一次,那么这两个函数均能正确返回目标位置,且不会出现失败情况,由此得到的结果在客户端看来是完全一指的,因此具有行为等价性。

二:规约(specification)含义

程序与客户端之间达成一致的约定,用于区分责任范围,客户端不需要了解调用函数的具体实现,只需要理解规约并使用。
在这里插入图片描述

三:规约结构

1.规约组成

precondition 前置条件:对客户端的约束,在使用方法时必须满足的条件。
postcondition 后置条件:对开发者的约束,方法结束时必须满足的条件,对实施者的义务。
exceptional behavior 意外行为:当前置条件违反时的处理结果

2.前置条件

方法签名中的参数数量和类型
requires中的附加条件:如参数类型、参数之间的交互等

3.后置条件

java可以静态检查的部分:返回类型、声明的异常检查
effects中的附加条件:如返回值与输入的关系、抛出异常的时间和类型、对象是否发生及怎样发生变化。

四:规约强弱判断:

规约变强:更放松的前置条件+更严个的后置条件
即,对实现者要求的越多(后置),规约越强;对客户端要求越多(前置),规约越弱。
例子:

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值