HashMap存储自定义类型键值以及Hashtable集合
HashMap存储自定义类型键值
Map集合保证key是唯一的:
作为key的元素,必须重写hashcode方法和equals方法,以保证key唯一
HashMap存储自定义类型键值第一种:
key :String类型
String类重写hashCode方法和equals方法,可以保证key唯一
value : Person类型
value可以重复(同名同年龄的人视为同一个)
public class Person { private String name; private int age; @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + '}'; } public Person() { } public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
private static void show01() { HashMap<String, Person> map = new HashMap<>(); map.put("北京",new Person("张三",14)); map.put("上海",new Person("李四",25)); map.put("四川",new Person("王五",16)); map.put("北京",new Person("赵六",36)); Set<String> keySet = map.keySet(); for (String key : keySet) { System.out.println(key+"="+map.get(key)); } }
两个相同的键存在,后添加的值覆盖了前面添加的值
HashMap存储自定义类型键值第二种:
key :Person
Person类必须重写hashCode方法和equals方法,以保证key唯一
value : String类型
可以重复
public class Person { private String name; private int age; @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Person person = (Person) o; return age == person.age && Objects.equals(name, person.name); } @Override public int hashCode() { return Objects.hash(name, age); } @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + '}'; } public Person() { } public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
private static void show02() { HashMap<Person, String> map = new HashMap<>(); map.put(new Person("张三",14),"北京"); map.put(new Person("李四",34),"上海"); map.put(new Person("王五",23),"重庆"); map.put(new Person("张三",14),"上海"); Set<Map.Entry<Person, String>> set = map.entrySet(); for (Map.Entry<Person, String> entry : set) { System.out.println(entry.getKey()+"="+entry.getValue()); } }
当对象作为键时,那么这个类就必须从写hashCode和equals方法,才可以保证键值的唯一
Hashtable集合
Hashtable<K ,V>集合implements Map<K,V>接口
Hashtable:底层也是一个哈希表,是一个线程安全的集合,是单线程集合,速度慢
HashMap:底层是一个哈希表,是一个线程不安全的集合,是多线程的集合,速度快
HashMap集合:可以存储nuLL值, nuLL键
Hashtable集合:不能存储null值, null键
Hashtable和vector集合一样,在jdk1.2版本之后被更先进的集合(HashMap ,ArrayList)取代了
public static void main(String[] args) { HashMap<String, String> map = new HashMap<>(); map.put(null,"456"); map.put("123",null); map.put(null,null); System.out.println(map); Hashtable<String, String> hashtable = new Hashtable<>(); hashtable.put(null,"张三"); hashtable.put("张三",null); hashtable.put(null,null); System.out.println(hashtable); }
根据运行结果可以看出HashMap集合可以存储null值,Hashtable集合不能存储null,否则汇报空指针异常。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix