Proszę sprawdzić poniżej mój kod, aby zrozumieć, czy klucz jest ArrayList w Mapie i jak JVM zrobi to dla wejść: tutaj piszę metoda hashCode i equals dla klasy TesthashCodeEquals.
package com.msq;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
class TesthashCodeEquals {
private int a;
private int b;
public TesthashCodeEquals() {
// TODO Auto-generated constructor stub
}
public TesthashCodeEquals(int a, int b) {
super();
this.a = a;
this.b = b;
}
public int getA() {
return a;
}
public void setA(int a) {
this.a = a;
}
public int getB() {
return b;
}
public void setB(int b) {
this.b = b;
}
public int hashCode() {
return this.a + this.b;
}
public boolean equals(Object o) {
if (o instanceof TesthashCodeEquals && o != null) {
TesthashCodeEquals c = (TesthashCodeEquals) o;
return ((this.a == c.a) && (this.b == c.b));
} else
return false;
}
}
public class HasCodeEquals {
public static void main(String[] args) {
Map<List<TesthashCodeEquals>, String> m = new HashMap<>();
List<TesthashCodeEquals> list1=new ArrayList<>();
list1.add(new TesthashCodeEquals(1, 2));
list1.add(new TesthashCodeEquals(3, 4));
List<TesthashCodeEquals> list2=new ArrayList<>();
list2.add(new TesthashCodeEquals(10, 20));
list2.add(new TesthashCodeEquals(30, 40));
List<TesthashCodeEquals> list3=new ArrayList<>();
list3.add(new TesthashCodeEquals(1, 2));
list3.add(new TesthashCodeEquals(3, 4));
m.put(list1, "List1");
m.put(list2, "List2");
m.put(list3, "List3");
for(Map.Entry<List<TesthashCodeEquals>,String> entry:m.entrySet()){
for(TesthashCodeEquals t:entry.getKey()){
System.out.print("value of a: "+t.getA()+", value of b: "+t.getB()+", map value is:"+entry.getValue());
System.out.println();
}
System.out.println("######################");
}
}
}
.
output:
value of a: 10, value of b: 20, map value is:List2
value of a: 30, value of b: 40, map value is:List2
######################
value of a: 1, value of b: 2, map value is:List3
value of a: 3, value of b: 4, map value is:List3
######################
to sprawdzi liczbę obiektów na liście i wartości valriabe w obiekcie. jeśli liczba obiektów jest taka sama, a wartości zmiennych instancji również są takie same, to rozważy duplikat klucza i zastąpi klucz.
teraz jeśli mogę zmienić tylko wartość obiektu na lista3
list3.add (nowa TesthashCodeEquals (2, 2));
następnie zostanie wydrukowana:
output
value of a: 2, value of b: 2, map value is:List3
value of a: 3, value of b: 4, map value is:List3
######################
value of a: 10, value of b: 20, map value is:List2
value of a: 30, value of b: 40, map value is:List2
######################
value of a: 1, value of b: 2, map value is:List1
value of a: 3, value of b: 4, map value is:List1
######################
tak, że zawsze sprawdzić liczbę obiektów na liście, a wartość zmiennej instancji obiektu.
dziękuję
Zostawiłbym nawet seterów i uczynił go niezmiennym. Prawdopodobnie nie ma powodu, aby zmieniać obiekty tej klasy po zakończeniu budowy. –
+1 - w rzeczywistości, to prawdopodobnie ** oszczędza ** spację, ponieważ klasa Bigram nie będzie miała nakładu 32-bitowego pola "długość". –