List.HashMap.TreeMap.HashSet,TreeSet以及集合排序
2014-10-31 11:30
465 查看
List可添加重复元素,按照添加的顺序排列,没有排序
Map以键值对添加元素,重复键元素会被覆盖掉,按照添加的顺序排列,没有排序
TreeMap元素以二叉树的方式升序排列
HashSet不可添加重复元素,元素无序,也没有排序
TreeSet不可添加重复元素,元素以二叉树的方式升序排列
Java API针对集合类型排序提供了两种支持:
java.util.Collections.sort(java.util.List)
java.util.Collections.sort(java.util.List, java.util.Comparator)
class Stucomparator implements Comparator<Stu>{
@Override
public int compare(Stu o1, Stu o2) {
return o1.id.compareTo(o2.id);
}
}
class Stu{
Integer id;
String name;
public Stu(Integer id,String name){
this.id=id;
this.name=name;
}
}
public static void main(String[] args) throws FileNotFoundException {
List<Stu> list=new ArrayList<Stu>();
list.add(new Stu(23,"aaa2"));
list.add(new Stu(45,"aaa3"));
list.add(new Stu(33,"aaa1"));
list.add(new Stu(33,"aaa1"));
}
Map以键值对添加元素,重复键元素会被覆盖掉,按照添加的顺序排列,没有排序
TreeMap元素以二叉树的方式升序排列
HashSet不可添加重复元素,元素无序,也没有排序
TreeSet不可添加重复元素,元素以二叉树的方式升序排列
Java API针对集合类型排序提供了两种支持:
java.util.Collections.sort(java.util.List)
java.util.Collections.sort(java.util.List, java.util.Comparator)
class Stucomparator implements Comparator<Stu>{
@Override
public int compare(Stu o1, Stu o2) {
//如果参数字符串等于此字符串,则返回 0 值;如果按字典顺序此字符串小于字符串参数,则返回一个小于 0 的值;如果按字典顺序此字符串
//大于字符串参数,则返回一个大于 0 的值。
return o1.id.compareTo(o2.id);
}
}
class Stu{
Integer id;
String name;
public Stu(Integer id,String name){
this.id=id;
this.name=name;
}
}
public static void main(String[] args) throws FileNotFoundException {
List<Stu> list=new ArrayList<Stu>();
list.add(new Stu(23,"aaa2"));
list.add(new Stu(45,"aaa3"));
list.add(new Stu(33,"aaa1"));
list.add(new Stu(33,"aaa1"));
}
相关文章推荐
- ArrayList、LinkedList和HashSet、TreeSet以及HashMap、TreeMap是如何实现存储的?
- HashSet和TreeSet,HashMap和TreeMap
- HashSet TreeSet LinkedList ArrayList Hashmap Treemap的一些区别
- Collect Set List HashSet ArrayList LinkedList TreeSet Map HashMap TreeMap
- ArrayList、LinkedList和HashSet、TreeSet以及HashMap、TreeMap是如何实现存储的?
- hashmap和treemap、hashset和treeset、linkedhashmap
- Java集合中的ArrayList LinkedList HashSet TreeSet HashMap TreeMap 的区别
- ArrayList、LinkedList和HashSet、TreeSet以及HashMap、TreeMap是如何实现存储的?
- ArrayList、LinkedList和HashSet、TreeSet以及HashMap、TreeMap是如何实现存储的?
- JANA-11.1-Set、HashSet与TreeSet;Map、HashMap与TreeMap讲解
- java中Collection/Collections;List/Set/Map;ArrayList/Vector/LinkedList;HashSet/HashMap/TreeSet/TreeMap
- 对象容器 - Java对数据结构的封装 - List, ArrayList, LinkedList, Set, SortedSet, HashSet, Map, TreeMap
- Set、HashSet、TreeSet、Map、HashMap、TreeMap
- HashMap,Hashset,ArrayList以及LinkedList集合的区别,以及各自的用法
- HashMap和HashSet的使用,区别。集合,Array、Collection(List/Set/Queue)、Map
- HashMap,Hashset,ArrayList以及LinkedList集合的区别和用法
- List、Map、Set、HashMap、HashSet、Hashtable
- HashMap,Hashset,ArrayList以及LinkedList集合的区别,以及各自的用法
- 集合二:Set、HashSet、TreeSet、Map、HashMap、TreeMap
- Set和List,HashSet与HasnMap,HashMap详解,HashSet详解