集合框架”支持Set接口两种普通的实现:HashSet和TreeSet。在更多情况下,会使用HashSet存储重复自由的集合。考虑到效率,添加到HashSet的对象需要采用恰当分配散列码的方式来实现hashCode()方法。当需要从集合中以有序的方式抽取元素时,TreeSet实现会有用处。为了能顺利进行,添加到TreeSet的元素必须是可排序的。
注意:为了安全,写上hashCode()方法
package cn.hncu.set;
import java.util.HashSet;
import java.util.Set;
//set在执行set.add()会执行hashcode里面的代码 而List不会
public class SetDemo {
public static void main(String[] args) {
Set set=new HashSet();
set.add(3);
set.add(new String("hncu"));
set.add(new String("java"));
set.add(new String("c++"));
set.add(new Integer(30));
set.add(123.45);
set.add(new Person("jack",30));
set.add(new Person("wja",50));
set.add(new Person("hhh",20));
for(Object obj:set){//在使用增强for循环进行集合的迭代的时候其实默认使用的是迭代器,
//因此在循环中不能使用集合的引用变量直接操作集合,避免导致多线程并发访问的安全性异常。
System.out.println(obj.toString());
}
}
}
package cn.hncu.set;
public class Person {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public Person() {
super();
}
@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;
Person other = (Person) 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;
}
}