1.HashSet javascript
java.util.HashSet类实现了Java.util.Set接口。java
它有以下特色:spa
1.它不容许出现重复元素;2.不保证集合中元素的顺序3.容许包含值为null的元素,但最多只能有一个null元素。code
下面代码是利用hashSet获取不重复的一组groupId:xml
public static List getGroups(List resourceList) {Set set = new HashSet();for (Resource resource : resourceList) {if (StringUtils.isNotBlank(resource.groupIds)) {for (String groupId : StringUtils.split(resource.groupIds, “,”)) {if (StringUtils.isNotBlank(groupId)) {set.add(Long.parseLong(groupId));}}}}return new ArrayList(set);}
2.TreeSet
TreeSet是能够实现排序等功能的集合,它在对象元素添加到集合中时会自动按照某种比较规则将其插入到有序的对象序列中;对象
TreeSet是如何对对象进行排序的捏?TreeSet支持 两种排序方式:天然排序和客户化排序,默认状况下是天然排序.在JDK中,有一部分类实现了Comparable接口,如Integer,Double和String等,Comparable接口有一个compareTo(Object o)方法,它返回整数类型,对于表达式x.compareTo(y),若是返回值为0,表示x和y相等,若是返回值大于0,表示x大于y,若是小于0,表示x TreeSet调用对象的compareTo()方法比较集合中对象的大小,而后进行升序排序,这种方式称为天然排序.客户化排序:java.util.Comparator接口用于指定具体的排序方式,它有个compare(Object obj1,Object obj2),用于比较两个对象的大小.当表达式compare(x,y)的值大于0,表示x大于y,小于0,表示x小于y,等于0,表示x等于y,若是想让TreeSet进按照Customer对象的name属性进行降序排列,能够先建立实现Comparator接口的类CustomerComparator,如:import java.util.*;public class CustomerComparator implements Comparator{public int compare(Object o1,Object o2){Customer c1=(Custoemr)o1;Customer c2=(Customer)o2;if(c1.getName().compareTo(c2.getName())>0) return -1;if(c1.getName().compareTo(c2.getName())<0) return 1;return 0;} }接下来在构造TreeSet的实例时,调用它的TreeSet(Comparator comparator)构造方法Set set=new TreeSet(new CustomerComparator());Customer c1=new Customer("TOM",15);Customer c2=new Customer("JACK",20);Customer c3=new Customer("MIKE",38);set.add(c1);set.add(c2);set.add(c3);Iterator it=set.iterator();while(it.hasNext()) {Custoemr customer=(Customer)it.next();System.out.println(customer.getName()+"" +customer.getAge();)}当TreeSet向集合中加入Customer对象时,会调用CustomerComparator类的compare()方法进行排序,以上Tree按照Custoemr对象的name属性进行降序排列,最后输出为:TOM 15 MIKE 38 JACK 16