重写equals 和hashCode 探解之洗洗脚(二)

接重写equals 和hashCode 探解之洗洗脚(一)



public class User{
public String userName;
public String password;

public User(String userName,String password){
this.userName = userName;
this.password = password;
}

public static void main(String[] arg){
Set<User> users = new HashSet<User>(); //L1
User user=new User("lisa","ddd"); //L2
users.add(user); //L3
User user1=new User("lisa","ddd"); //L4
users.add(user1); //L5
System.out.println(“size---->"+users.size()); //L6
}

//重写hashCode和equals方法
public int hashCode(){

system.out.println("fn ----> hashCode");
return 1;
}

public boolean equals(){
system.out.println("fn ----> equals");
return true;
}

}


执行结果:
fn ----> hashCode
fn ----> hashCode
fn ----> equals
size---->1



分析: 在添加user 到users中,打印fn ----> hashCode 。原理见上篇文章。
L5: 添加user1到users中,hashCode()依然 return 1;因此可以理解为 在将user 放到第一个房间后,又准备将user1 放到同一个房间(即第一个房间user所在的房间,注意user此刻仍在第一个房间里睡觉哟)里去。

现在user1也准备进这个房间睡觉了,这时门禁就会开始判断了,你user和user1是不是同一个人啊? 是同一个人,我就让你进,不是那你就不是同一个人,我就不让你进来哟。

如果这个时候门禁是正常工作的,肯定就不让你进了,因为里面有人了啊,如果门禁处于损坏状态,那你就可以大摇大摆的闯进去YY了(嘿嘿),

那么门禁的好坏就要根据equals()方法来判断了,这里我们的equals 方法始终返回的是true ,说明门禁是永远处于正常工作的哟,你坏人休息进来YY。于是房间里就永远是一个人在睡觉了哟,呵呵(除非遇上了楼垮垮)

于是就打印了2次 fn ----> hashCode 和一次判定 fn ----> equals,当然size永远是1了。

------------------------------------------



public boolean equals(){
system.out.println("fn ----> equals");
return true;
}


如果我们此时将equals 方法的return false; 那门禁就坏掉了,那么坏人 user1就可以破门而入了,甚至还可以进入更多的“user1”.....

可想而知,打印的就是:

fn ----> hashCode
fn ----> hashCode
fn ----> equals
size---->2

因此我们根据不同的业务重写equals 方法,不同的条件返回不同的boolean ,就可以为所欲为的控制人员进出了。看来贿赂哈门禁的确比较爽哈。

继续
重写equals 和hashCode 探解之洗洗脚(三)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值