软构笔记-8-ADT和OOP中的“等价性”

Posted blogstb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软构笔记-8-ADT和OOP中的“等价性”相关的知识,希望对你有一定的参考价值。

软构8

本章大纲:

  • 理解特性之间的等价关系
  • 站在观察者角度,利用AF,定义不可变对象之间的等价关系
  • 引用等价性和对象等价性
  • 可变数据类型的观察等价性和行为等价性
  • 理解 Object 的契约,正确实现等价关系判定

ADT 的等价操作

  • ADT 是对数据的抽象

  • 抽象函数 AF :内部表示抽象表示

  • 基于抽象函数 AF 定义 ADT 的等价操作

不可变数据类型的等价性

  • 使用AF来判断
    AF映射到同样的结果,则等价
  • 通过观察来判断
    站在外部观察者角度:对两个对象调用任何相同的操作,都会得到相同的结果,则认为这两个对象是等价的。反之亦然!

== vs. equals()

  • == :引用等价性
  • equals() :对象等价性

在自定义 ADT 时,需要重写Object的equals()

对基本数据类型,使用 == 判定相等
对对象类型,使用 equals()

public class Object 
	...
	public boolean equals(Object that) 
		return this == that;
	

在Object中实现的缺省equals()是在判断引用等价性。

可变数据类型的等价性

两种方法:

  • 观察等价性: 在不改变状态的情况下,两个mutable对象是否看起来一致
  • 行为等价性: 调用对象的任何方法都展示出一致的结果

抽象数据类型(ADT)和面向对象编程(OOP)3.5 ADT和OOP中的等价性

instancsof动态类型检查。除了在判断是否与应生成的类型一样外都不使用,getClass()同样

==引用等价性

equals()对象等价性  基本数据类型使用

在自定义ADT时需要重写Object的equals()   对象类型使用

a.equals(null) returns false

equals()的自反性:自己等自己   传递性:a等b,b等c,则a等c   对称性:a等b,则b等a

重写equals()必须也要重写hashCode(),相等的对象必须具有相同的散列码,如果没有重写,会从Object中得到一个,它是基于对象的地址。

hashCode() 技术分享图片

 

可变对象的观察等价性、行为等价性

当两个对象不能通过观察区别,则等价

观察等价性:通过只调用observer,producer和creator方法。 这测试两个参考在程序的当前状态中是否“看起来”相同

行为等价性:不能通过任何代码加以区分即使在一个代码上调用了mutator,而另一个代码则不会调用它。 这将测试这两个引用在这个和所有将来的状态中是否会“表现”相同。

对于不可变的对象,观察和行为的平等是相同的,因为没有任何增变方法

对于可变对象倾向于观察等价性

大多数可变数据类型(例如Collections)使用观察等价性

其他可变类(如StringBuilder)使用行为等价性

有时观察等价性会有bug,甚至破坏RI

可变类型实现行为等价性即可,只有只想同样内存空间的object才相等,可变类型只需要从Object继承equals()  hashCode()即可

一定要观察等价性可以写一个新方法

 不可变类型一定要重写equals()和hashCode()

以上是关于软构笔记-8-ADT和OOP中的“等价性”的主要内容,如果未能解决你的问题,请参考以下文章

软构学习-56-设计规约抽象数据类型(ADT)

抽象数据类型(ADT)和面向对象编程(OOP)3.5 ADT和OOP中的等价性

软构笔记-9-面向复用的软件构造技术

软件构造 第三章第五节 ADT和OOP中的等价性

第五部分

软构学习-4-数据类型与类型检验