Java 覆盖hashcode()和equals()的HashMap在我的情况下不起作用

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.

这是我第一次发布这个问题

请帮我解决我的问题。 在这段代码中,我使用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.
我为此实现了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”。我应该使用什么方法。我认为上述方法是正确的。