由于ArrayList的函数“contains”与两个对象的函数hashcode & equals进行比较,所以必须重写Class ListTableClass的函数“hashCode”&“equals”。
示例:
import java.util.ArrayList;
public class ListTableClass {
private String name;
private int age;
public ListTableClass(String name, int age) {
super();
this.name = name;
this.age = age;
}
public static void main(String[] args) {
ArrayList<ListTableClass> ltc = new ArrayList<ListTableClass>();// has duplicate
ListTableClass obj0 = new ListTableClass("A", 0);
ListTableClass obj1 = new ListTableClass("B", 1);
ListTableClass obj2 = new ListTableClass("C", 2);
ListTableClass obj3 = new ListTableClass("A", 0);
ltc.add(obj0);
ltc.add(obj1);
ltc.add(obj2);
ltc.add(obj3);
ArrayList<ListTableClass> ltc2 = new ArrayList<ListTableClass>();// unique
for (ListTableClass element : ltc) {
if (!ltc2.contains(element)) {
System.out.println(element);
ltc2.add(element);
}
}
}
}
覆盖hashCode之前的输出:
y2015.m06.d10.ListTableClass@659e0bfd //obj0 {"A", 0}
y2015.m06.d10.ListTableClass@2a139a55 //obj1 {"B", 1}
y2015.m06.d10.ListTableClass@15db9742 //obj2 {"C", 2}
y2015.m06.d10.ListTableClass@6d06d69c //obj3 {"A", 0} is different from obj0
添加覆盖函数hashCode:
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
ListTableClass other = (ListTableClass) obj;
if (age != other.age)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
那么输出是:
y2015.m06.d10.ListTableClass@402 //obj0
y2015.m06.d10.ListTableClass@422 //obj1
y2015.m06.d10.ListTableClass@442 //obj2
没有obj3,因为obj3的hashcode &它的属性和obj0相等