浅谈java Collection中的排序问题
这里讨论list、set、map的排序,包括按照map的value进行排序。
1)list排序
list排序可以直接采用Collections的sort方法,也可以使用Arrays的sort方法,归根结底Collections就是调用Arrays的sort方法。
publicstatic<T>voidsort(List<T>list,Comparator<?superT>c){ Object[]a=list.toArray(); Arrays.sort(a,(Comparator)c); ListIteratori=list.listIterator(); for(intj=0;j<a.length;j++){ i.next(); i.set(a[j]); } }
如果是自定义对象,需要实现Comparable接口使得对象自身就有“比较”的功能,当然我们也可以在外部使用Comparator来规定其排序。
例如:
packagecom.fox; /** *@authorhuangfox *@desc */ publicclassUserimplementsComparable<User>{ privateStringname; privateintage; publicUser(){ } publicUser(Stringname,intage){ super(); this.name=name; this.age=age; } @Override publicStringtoString(){ return"name:"+name+",age:"+age; } publicStringgetName(){ returnname; } publicvoidsetName(Stringname){ this.name=name; } publicintgetAge(){ returnage; } publicvoidsetAge(intage){ this.age=age; } @Override publicintcompareTo(Usero){ if(o.age<this.age) return1; elseif(o.age>this.age) return-1; else return0; } /** *@paramargs */ publicstaticvoidmain(String[]args){ Useru1=newUser("fox",11); Useru2=newUser("fox2",21); System.out.println(u2.compareTo(u1)); } }
排序:
//List<User>us=newArrayList<User>(); List<User>us=newLinkedList<User>(); us.add(newUser("f5",12)); us.add(newUser("f2",22)); us.add(newUser("f3",2)); us.add(newUser("f4",14)); us.add(newUser("f5",32)); us.add(newUser("f4",12)); us.add(newUser("f7",17)); us.add(newUser("f8",52)); System.out.println(us.toString()); longbt=System.nanoTime(); Collections.sort(us,newComparator<User>(){ @Override publicintcompare(Usero1,Usero2){ if(o1.getAge()<o2.getAge()) return-1; elseif(o1.getAge()>o2.getAge()) return1; else returno1.getName().compareTo(o2.getName()); } }); longet=System.nanoTime(); System.out.println(et-bt); System.out.println(us.toString());
当然这里可以直接Collections.sort(us),这里用Comparator对User自身的比较方法compareTo做了一点点优化(对相同年龄的人根据用户名排序,String的排序)。
简单提一下,Arrays的排序采用的是插入排序和归并排序,当数组长度较小时直接插入排序。
2)set排序
set包括HashSet和TreeSet,HashSet是基于HashMap的,TreeSet是基于TreeMap的。
TreeMap是用红黑树实现,天然就具有排序功能,“天然就具有排序功能”是指它拥有升序、降序的迭代器。
那么HashSet怎么排序呢?我们可以将HashSet转成List,然后用List进行排序。
例如:
Set<User>us=newHashSet<User>(); //Set<User>us=newTreeSet<User>(); //Set<User>us=newTreeSet<User>(newComparator<User>(){ // //@Override //publicintcompare(Usero1,Usero2){ //if(o1.getAge()<o2.getAge()) //return-1; //elseif(o1.getAge()>o2.getAge()) //return1; //else //returno1.getName().compareTo(o2.getName()); //} //}); us.add(newUser("f5",12)); us.add(newUser("f2",22)); us.add(newUser("f3",2)); us.add(newUser("f4",14)); us.add(newUser("f5",32)); us.add(newUser("f4",12)); us.add(newUser("f7",17)); us.add(newUser("f8",52)); //set->array List<User>list=newArrayList<User>(us); System.out.println(list); Collections.sort(list); System.out.println(list);
也可以将HashSet转换成数组用Arrays排序。
3)map排序
map包括HashMap和TreeMap,上面已经提过,TreeMap用红黑树实现,天然具有排序功能。
那么HashMap怎么按“key”排序呢?方法很简单,用HashMap来构造一个TreeMap。
Map<String,Integer>us=newHashMap<String,Integer>(); //Map<String,Integer>us=newTreeMap<String,Integer>(); us.put("f1",12); us.put("f2",13); us.put("f5",22); us.put("f4",42); us.put("f3",15); us.put("f8",21); us.put("f6",123); us.put("f7",1); us.put("f9",19); System.out.println(us.toString()); System.out.println(newTreeMap<String,Integer>(us));
怎么按照“value”进行排序?
//按照value排序 Set<Entry<String,Integer>>ks=us.entrySet(); List<Entry<String,Integer>>list=newArrayList<Map.Entry<String,Integer>>( ks); Collections.sort(list,newComparator<Entry<String,Integer>>(){ @Override publicintcompare(Entry<String,Integer>o1, Entry<String,Integer>o2){ if(o1.getValue()<o2.getValue()) return-1; elseif(o1.getValue()>o2.getValue()) return1; return0; } }); System.out.println(list);
将map的Entry提出成set结构,然后将set转成list,最后按照list进行排序。
以上这篇浅谈javaCollection中的排序问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。