HashSet

499阅读 0评论2009-10-07 sytrydor
分类:Java

实现Set接口的hash table(哈希表),依靠HashMap来实现的。
我们应该为要存放到散列表的各个对象定义hashCode()和equals()。
import java.util.*;
class HashSetTest
{
 public static void main(String[] args)
 {
  HashSet hs=new HashSet();
  /*hs.add("one");
  hs.add("two");
  hs.add("three");
  hs.add("one");*/
  hs.add(new Student(1,"zhangsan"));
  hs.add(new Student(2,"lisi"));
  hs.add(new Student(3,"wangwu"));
  hs.add(new Student(1,"zhangsan"));
  
  Iterator it=hs.iterator();
  while(it.hasNext())
  {
   System.out.println(it.next());
  }
 }
}
class Student
{
 int num;
 String name;
 Student(int num,String name)
 {
  this.num=num;
  this.name=name;
 }
 public int hashCode()
 {
  return num*name.hashCode();
 }
 public boolean equals(Object o)
 {
  Student s=(Student)o;
  return num==s.num && name.equals(s.name);
 }
 public String toString()
 {
  return num+":"+name;
 }
}
上一篇:ArrayList和LinkedList的比较
下一篇:散列表