HashSet与HashMap比较——添加对象已存在处理方式一样?

答案是不一样的。

HashSet与HasMap在添加新对象是,会先判断容器中是否已存在相等的对象(比较key是否相等),如果存在,HashSet的处理方式是放弃存储新对象,然而HashMap的处理方式是覆盖之前的对象。

相等对象:如果两个引用指向同一个对象,那么这两个引用是相等的,他们的hashcode方法返回的值一致。如果没有重写Object中hashcode方法,返回的是对象在内存中的地址(值中带有‘@’)。所以必须要要重写hashCode()方法,才能使得两个对象都有相同的hashCode,并且还要重写equals()方法使得返回的值为true。满足这两个条件,那么证明两个对象在HashMap/HashSet中是相等的。

用一段测试代码来展示:

import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Objects;
import java.util.Set;


import lombok.Data;

public class TestHashSetAndHashMap {
  @Data
  public static class Person {
    private Integer id;
    private String name;

    public Person(Integer id, String name) {
      this.id = id;
      this.name = name;
    }

    public Person(){}

    @Override
    public boolean equals(Object o) {
      if (this == o) return true;
      if (o == null || getClass() != o.getClass()) return false;
      Person person = (Person) o;
      return Objects.equals(id, person.id);
    }

    @Override
    public int hashCode() {

      return Objects.hash(id);
    }
  }
  public static void main(String[] args) {
    Person p1 = new Person(1,"zhangshan");
    Person p2 = new Person(1, "Lisi");
    Set<Person> set = new HashSet<>();
    set.add(p1);
    for (Person p : set) {
      System.out.println(p.getName());
    }
    set.add(p2);
    for (Person p : set) {
      System.out.println(p.getName());
    }
    //HashMap是覆盖
    Map<Integer, Person> map = new HashMap<>();
    map.put(p1.getId(), p1);
    for (Map.Entry e : map.entrySet()) {
      System.out.println(e.getValue());
    }
    map.put(p2.getId(), p2);
    for (Map.Entry e : map.entrySet()) {
      System.out.println(e.getValue());
    }
  }
}

结果:

32
32
zhangshan
zhangshan
TestHashSetAndHashMap.Person(id=1, name=zhangshan)
TestHashSetAndHashMap.Person(id=1, name=Lisi)

可以看出HashSet放弃存储新对象,HashMap直接覆盖原有对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值