存储无序的,不可重复的元素,Set中常用的方法都是Collection下定义的。这里面的顺序是无序,但不是随机排序的。其中的不可重复性,当向Set中添加进相同的元素的时候,后面的这个不能添加进去。要求添加进Set中元素所在的类,一定要重写equals()和hashCode()方法,进而保证元素添加的不可重复性。
当向Set中添加对象时,首先调用此对象所在类的hashCode()方法计算此对象的哈希值,此哈希值决定了此对象在Set中的存储位置,若此位置之前没有对象存储,则这个对象直接存储到此位置。若此位置已有对象存储。再通过equals()比较这两个对象是否相同。如果相同,后一个对象就不能再添加进来。
使用链表,维护了一个添加进集合中的顺序,导致当我们遍历LinkedHashSet集合元素时,是按照添加进去的顺序遍历的。
import java.util.Comparator; import java.util.HashSet; import java.util.TreeSet; public class TestSet { public static void main(String[] args) { //1.创建一个实现了Comparator接口的类对象 Comparator comparator = new Comparator() { //向TreeSet中添加Customer对象,在此方法中指明是按照Customer的哪个属性排序的 @Override public int compare(Object o1, Object o2) { if (o1 instanceof Customer && o2 instanceof Customer) { Customer c1 = (Customer) o1; Customer c2 = (Customer) o2; int i = c1.getName().compareTo(c2.getName()); if (i == 0) { return c1.getAge().compareTo(c2.getAge()); } else { return i; } } return 0; } }; //2.将此对象作为形参传递给TreeSet的构造器中 TreeSet set = new TreeSet(comparator); set.add(new Customer("AA", 103)); set.add(new Customer("BB", 102)); set.add(new Customer("GG", 104)); set.add(new Customer("CC", 101)); set.add(new Customer("CC", 107)); for (Object object : set) { System.out.println(object); } } }
运行结果