ADT和OOP的等价性学习笔记1

认识等价性的方式

  • ADT中操作的等价性
    基于抽象函数定义ADT的等价操作
  • 使用AF定义等价性
    如果AF映射到相同的结果,则等价
    由AF导出的关系是等价关系
  • 使用观察器来定义等价性
    对两个对象调用任何相同的操作,都会得到相同的结果。

==和.equals()

  • 对于基本数据类型,均使用前者
  • 对于对象数据类型,使用后者。
    -缺省情况下如果不重写equals方法,则判断两个对象引用的地址是否一致
    -应该总是使用后者判断相同。如果判断逻辑是内存地址相等,则不需要重写。如果判断逻辑是特定的,则需要重写。无论哪种情况,都能达到期望的目的

实现.equals方法

  • 注意Overload与override的区别
    -重写的参数必须是Object类型,否则变成overload,得到与预期不一致的结果

  • override时总是加上@override符号,保证编译器检查的正确性。

  • 严格来说,没有AF的情况下判断每个fileds的等价性,是不正确的

  • instance of用于判断某个对象是不是特定的类型(或其子类型)。使用动态类型检查而不是静态类型检查。
    -使用instance of是一个在OOP中不好的习惯,除了在实现.equals方法时
    -getclass也是
    -可以使用多态避免

  • 相等的对象,hashcode值一定要一致。这是一个十分subtel的问题。来康康下面的例子:

public class person {

	private final String name;
	
	public person(String name)
	{
		this.name = name;
		
	}
	
	public String getname()
	{
		return name;
		
	}
	@Override
	public boolean equals(Object that)
	{
		if(!(that instanceof person))
			return false;
		return ((person)that).getname().equals(name);
		
		
		
	}
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Map<person,Integer> a = new HashMap<>();
		person b = new person("1");
		person c = new person("1");
		System.out.println(b.equals(c));
		a.put(b,1);
		System.out.println(a.get(b));
		System.out.println(a.get(c));
	}

}

执行后程序的输出结果如图所示。

在这里插入图片描述
在这里插入图片描述

最后一行说明说明并没有找到对应键值。而我们明白由于重写了equals方法,那么实际上两个new出来的person是一致的。究其原因是没有重写hashcode的值,缺省情况下两个person对象地hashcode值是不一致的(不同地内存地址)。
现在重写hashcode函数,简单地让其返回0,再次运行代码得到了预期地结果
在这里插入图片描述
如果我们再引入一个person对象d,那么显然与前两个对象都具有相同的hashcode值,但是,确与前两个对象不equal。

在这里插入图片描述
运行后输出null。综上所述,可知java中维护的hashtable长这个样:
在这里插入图片描述
不相等的对象应该有不同的hashcode

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值