文档章节

将LinkedHashMap中按照名称中含有某个文字的索引大小进行排序

文文1
 文文1
发布于 2017/03/01 09:30
字数 301
阅读 39
收藏 1

LinkedHashMap本身不能排序,它是按照插入的顺序来取数据的,所以这里要把一个正确排序的新的LinkedHashMap对象赋值给原来需要排序的对象:

Map<Long,String> rateStdList=new LinkedHashMap<Long,String>();
//..省略往rateStdList中添加元素的过程
List<Map.Entry<Long, String>> infoIds = new ArrayList<Map.Entry<Long, String>>(rateStdList.entrySet());  
// 按照库名中含有养护的费率库放在前面
Collections.sort(infoIds, new Comparator<Map.Entry<Long, String>>() {  
	public int compare(Map.Entry<Long, String> o1,  
			Map.Entry<Long, String> o2) {  
		return (o2.getValue().indexOf("养护")-o1.getValue().indexOf("养护"));  
	}  
});  

Map<Long,String> sortRateStdList=new LinkedHashMap<Long,String>(); 
for (int i = 0; i < infoIds.size(); i++) {  
	Entry<Long,String> ent=infoIds.get(i);  
	sortRateStdList.put(ent.getKey(),ent.getValue()) ;
};
//最后把排序号的新的LinkedHashMap赋值给原来的rateStdList 
rateStdList = sortRateStdList;

另外再给个实例:

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());  
      
}  

 

© 著作权归作者所有

共有 人打赏支持
文文1
粉丝 21
博文 351
码字总数 117723
作品 0
长沙
程序员
HashMap,LinkedHashMap,TreeMap的区别

Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复。 Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访...

浮躁的码农
2015/07/29
0
0
Java集合 --- LinkedHashMap底层实现和原理(源码解析)

概述 文章的内容基于JDK1.7进行分析,之所以选用这个版本,是因为1.8的有些类做了改动,增加了阅读的难度,虽然是1.7,但是对于1.8做了重大改动的内容,文章也会进行说明。 LinkedHashMap,见...

起个名忒难
2017/09/24
0
0
Java核心数据结构(List,Map,Set)使用技巧与优化

JDK提供了一组主要的数据结构实现,如List、Map、Set等常用数据结构。这些数据都继承自 java.util.Collection 接口,并位于 java.util 包内。 1、List接口 最重要的三种List接口实现:Array...

巅峰小学生
08/27
0
0
【全程干货】搜索引擎是如何建立索引的?

索引结构如果建立好了,可以提高搜素的速度,那么给定一个文档集合,索引是如何建立起来的?建立索引的方式有很多种,本文讲解比较实用的3种建立索引的方法。 两边文档遍历法 顾名思义,此方...

努力拼搏的80后
03/22
0
0
HashMap,LinkedHashMap,TreeMap的有序性

HashMap 是将 Key 做 Hash 算法,然后将 Hash 值映射到内存地址,直接取得 Key 所对应的数据。在 HashMap 中,底层数据结构使用的是数组,所谓的内存地址即数组的下标索引。HashMap 的高性能...

小杰java
03/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周日乱弹 —— 小心着凉 @红薯

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @莱布妮子:5.33起,其声呜呜然,如怨如慕,如泣如诉。余音袅袅,不绝如缕。分享Arch Enemy的单曲《Bridge Of Destiny (2009)》 《Bridge Of...

小小编辑
今天
259
4
what f,,

anlve
今天
9
0
初级开发-编程题

` public static void main(String[] args) { System.out.println(changeStrToUpperCase("user_name_abc")); System.out.println(changeStrToLowerCase(changeStrToUpperCase("user_name_abc......

小池仔
今天
15
0
现场看路演了!

HiBlock
昨天
23
0
Rabbit MQ基本概念介绍

RabbitMQ介绍 • RabbitMQ是一个消息中间件,是一个很好用的消息队列框架。 • ConnectionFactory、Connection、Channel都是RabbitMQ对外提供的API中最基本的对象。Connection是RabbitMQ的s...

寰宇01
昨天
18
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部