Java 覆盖hashcode()和equals()的HashMap在我的情况下不起作用
这是我第一次发布这个问题 请帮我解决我的问题。 在这段代码中,我使用HasMap存储键值对,这里的键是字符串,有三个子字符串,由“”空格分隔符分隔 比如说,Java 覆盖hashcode()和equals()的HashMap在我的情况下不起作用,java,Java,这是我第一次发布这个问题 请帮我解决我的问题。 在这段代码中,我使用HasMap存储键值对,这里的键是字符串,有三个子字符串,由“”空格分隔符分隔 比如说, String t1 = new String("A B C"); and stored in HashMap as- m.put(t1,27); 这里,A、B和C是三个不同的字符串。其中,假设A、B、C的不同组合是唯一的 Like "A B C", "B A C", "C B A" are all treated as equal.
String t1 = new String("A B C");
and stored in HashMap as-
m.put(t1,27);
这里,A、B和C是三个不同的字符串。其中,假设A、B、C的不同组合是唯一的
Like "A B C", "B A C", "C B A" are all treated as equal.
我为此实现了hashCode()和equal(),
下面的代码只能打印
A B C:61046662
但它甚至没有调用hashCode()或equals()。请给我一些建议
public class Test {
public int hashCode(){
System.out.println("hashcode method called");
return this.toString().length();
}
public boolean equals(Object obj) {
System.out.println("equal method called ");
int count = 0;
if(!(obj instanceof String))
return false;
if (obj == this)
return true;
count = 0;
StringTokenizer st = new StringTokenizer(((String)obj).toString(), " ");
while(st.hasMoreTokens()){
if(this.toString().contains(st.nextToken())){
count ++;
}
}
return (count == 3);
}
public static void main(String[] args) {
HashMap<String, Integer> m = new HashMap<String, Integer>();
String t1 = new String("A B C");
String t2 = new String("B A C");
String t3 = new String("C B A");
m.put(t1, 27);
m.put(t2, 34);
m.put(t3, 45);
System.out.println(m.get("A B C"));
for(Entry e : m.entrySet()){
System.out.println(((String)e.getKey())+":" +e.getKey().hashCode());
}
}
}
公共类测试{
公共int hashCode(){
System.out.println(“调用hashcode方法”);
返回此.toString().length();
}
公共布尔等于(对象obj){
System.out.println(“调用的相等方法”);
整数计数=0;
如果(!(字符串的obj实例))
返回false;
如果(obj==此)
返回true;
计数=0;
StringTokenizer st=新的StringTokenizer(((String)obj.toString(),“”);
而(st.hasMoreTokens()){
if(this.toString()包含(st.nextToken())){
计数++;
}
}
返回(计数=3);
}
公共静态void main(字符串[]args){
HashMap m=新的HashMap();
字符串t1=新字符串(“A B C”);
字符串t2=新字符串(“B A C”);
字符串t3=新字符串(“C B A”);
m、 put(t1,27);
m、 put(t2,34);
m、 put(t3,45);
System.out.println(m.get(“abc”);
对于(条目e:m.entrySet()){
System.out.println(((字符串)e.getKey())+”:“+e.getKey().hashCode());
}
}
}
您的equals()
和hashCode()
方法不会出现在图片中,因为映射键的类型为String
,而不是Test
类型。因此,使用标准字符串比较和哈希代码
您需要修改
Test
,使其保存字符串,并相应地更改equals()
和hashCode()
。然后需要将映射更改为HashMap
类型。密钥的hashCode用于确定密钥的位置和唯一性。您正在向映射添加字符串对象,因此使用String.hashCode方法。
虽然您已经为测试类实现了hashCode,但是没有使用它们
为了解决您的问题,您可以创建自己的类作为键,并使用自己的hashCode实现。
使用您的示例,您可以向测试类中添加一个可以保存字符串的属性,并将该测试类用作映射中的键。两者互不相关。你根本不用考试课谢谢你的指导。好的,我理解为什么它不起作用的概念。现在我需要的是,我有和上面一样的HashMap。我需要从条目中删除重复的“abc”。我应该使用什么方法。我认为上述方法是正确的。