java中的单链表_java 中单链表的equals方法

展开全部

LinkedList对equals的定义大致是这样的:(下文将equals 写作32313133353236313431303231363533e4b893e5b19e31333337616464 相等)

两个链表相等当且仅当其大小相等,并且每个对应元素也相等。

谈到相等,必须谈及hashCode方法,关系如下:hashCode相等的 可能相等(相等与否需进一步检测)

hashCode不等的 一定不等(排除相等情况)

一般情况下,hashCode的计算一定比equals快,而且‘不等’的情况较多,因此作为判断相等的加速方案,java会先检测hashCode,若不等,则对象一定不等。

那么,对于java的常见类,例如:基本类型包装类、集合类、字符串类等 其 equals 与 hashCode已经写好,不用我们操心。

若是自定义类,一定要重新equals与hashCode方法,满足上述hashCode的2个关系。

例如自己的User类有name和pass,一个简单的方案如下:

public class User{

String name,pass;

//get/set....

public int hashCode() {

return name.hashCode + pass.hashCode();

}

public boolean equals(Object o) {

if(o instanceof User) {

User u = (User)o;

return (name.equals(u.name))&&(pass.equals(u.pass));

}

return false;

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值