你说的按要求排序,应该是有一些自定义规则排序吧,假如要通过值来排序可以用以下方法:
Java代码
public static void main(String[] args) {
Map<String, Integer> map = new HashMap<String, Integer>();
map.put("lisi", 5);
map.put("lisi1", 1);
map.put("lisi2", 3);
map.put("lisi3", 9);
List<Map.Entry<String, Integer>> infoIds = new ArrayList<Map.Entry<String, Integer>>(
map.entrySet());
System.out.println("--------------排序前--------------");
for (int i = 0; i < infoIds.size(); i++) {
String id = infoIds.get(i).toString();
System.out.println(id);
}
// 排序
Collections.sort(infoIds, new Comparator<Map.Entry<String, Integer>>() {
public int compare(Map.Entry<String, Integer> o1,
Map.Entry<String, Integer> o2) {
return ( o1.getValue()-o2.getValue());
}
});
System.out.println("--------------排序后--------------");
for (int i = 0; i < infoIds.size(); i++) {
Entry<String,Integer> ent=infoIds.get(i);
System.out.println(ent.getKey()+"="+ent.getValue());
一、map是键值对的集合接口,它的实现类主要包括:hashmap,treemap,hashtable以及linkedhashmap等。其中这四者的区别如下(简单介绍): 1、hashmap:我们最常用的map,它根据key的hashcode 值来存储数据,根据key可以直接获取它的value,同时它具有很快的访问速度。hashmap最多只允许一条记录的key值为null(多条会覆盖);允许多条记录的value为 null。非同步的。 2、treemap: 能够把它保存的记录根据key排序,默认是按升序排序,也可以指定排序的比较器,当用iterator 遍历treemap时,得到的记录是排过序的。treemap不允许key的值为null。非同步的。 3、hashtable: 与 hashmap类似,不同的是:key和value的值均不允许为null;它支持线程的同步,即任一时刻只有一个线程能写hashtable,因此也导致了hashtale在写入时会比较慢。 4、linkedhashmap: 保存了记录的插入顺序,在用iterator遍历linkedhashmap时,先得到的记录肯定是先插入的.在遍历的时候会比hashmap慢。key和value均允许为空,非同步的。 二、 1、treemap treemap默认是升序的,如果我们需要改变排序方式,则需要使用比较器:comparator。 1)comparator可以对集合对象或者数组进行排序的比较器接口,实现该接口的public compare(t o1,to2)方法即可实现排序,该方法主要是根据第一个参数o1,小于、等于或者大于o2分别返回负整数、0或者正整数。 2)对value排序我们就需要借助于collections的sort(list list, comparatorsuper t> c)方法,该方法根据指定比较器产生的顺序对指定列表进行排序。但是有一个前提条件,那就是所有的元素都必须能够根据所提供的比较器来进行比较。 2、hashmap 我们都是hashmap的值是没有顺序的,他是按照key的hashcode来实现的。
Hadoop|
Apache Pig|
Apache Kafka|
Apache Storm|
Impala|
Zookeeper|
SAS|
TensorFlow|
人工智能基础|
Apache Kylin|
Openstack|
Flink|
MapReduce|
大数据|
云计算|
用户登录
还没有账号?立即注册
用户注册
投稿取消
文章分类: |
|
还能输入300字
上传中....