我正在尝试用这种方式构建一个有两个键的HashMap:首先我创建了一个只是数据结构的类.
public class Tarta {
public String nome;
public String data;
public Tarta(String nome, String data) {
this.nome = nome;
this.data = data;
}
public String getNome() {
return nome;
}
public void setNome(String nome) {
this.nome = nome;
}
public String getData() {
return data;
}
public void setData(String data) {
this.data = data;
}
}
Run Code Online (Sandbox Code Playgroud)
然后我通过在另一个类中写这个来填充我的地图:
mappaTarta.put(new Tarta(nome, data), peso);
Run Code Online (Sandbox Code Playgroud)
在编译期间我没有错误,但是在测试时我得到了null,例如:
System.out.println(lr.leggiRecord().get(new Tarta("R", "15/11/2015")));
Run Code Online (Sandbox Code Playgroud)
你能解释一下为什么吗?谢谢
And*_*ner 13
如果要将项目用作a中的键HashMap,则需要覆盖它们equals和hashCode方法.否则,默认实现将考虑使用相同参数创建的两个实例,因为它们是两个不同的实例.
目前:
Tarta a = new Tarta("foo", "bar");
Tarta b = new Tarta("foo", "bar");
System.out.println(a == b); // false
System.out.println(a.equals(b)); // false
System.out.println(a.hashCode() == b.hashCode()); // false
Run Code Online (Sandbox Code Playgroud)
示例实现:
@Override public boolean equals(Object other) {
if (other == this) return true;
if (other instanceof Tarta) {
Tarta that = (Tarta) other;
return Objects.equals(this.name, that.name)
&& Objects.equals(this.data, that.data);
}
return false;
}
@Override public int hashCode() {
return Objects.hash(name, data);
}
Run Code Online (Sandbox Code Playgroud)
然后:
Tarta a = new Tarta("foo", "bar");
Tarta b = new Tarta("foo", "bar");
System.out.println(a == b); // false - they are still different instances
System.out.println(a.equals(b)); // true
System.out.println(a.hashCode() == b.hashCode()); // true
Run Code Online (Sandbox Code Playgroud)
请注意,建议仅将不可变对象用作HashMaps中的键:您应该至少制作name和data最终,并使类final也使其真正不可变.
| 归档时间: |
|
| 查看次数: |
667 次 |
| 最近记录: |