一、核心要点
* map的自定义key
* map使用put方法的存入的时候,有关乎到hash码
* 在使用get方法获取数据的时候,也是通过key的hash码
* 在使用getNode方法的时候又使用到了 equals方法
* 在map上如果产生了hash冲突,会在冲突位置采用链表的方式存储
二、完整代码
package collectjh.map;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
public class DefineKey {
public static void main(String[] args) {
Map<Person, Integer> map = new HashMap<Person, Integer>();
map.put(new Person("张三" , 24) , 5555);
System.out.println(map.get(new Person("张三" , 24)));
}
}
class Person{
private String name;
private int age;
public Person(String name , int age) {
this.name = name;
this.age = 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 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;
}
}
三、运行结果
5555