文档章节

将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
博文 373
码字总数 119521
作品 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
HashMap,LinkedHashMap,TreeMap的有序性

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

小杰java
03/08
0
0
【全程干货】搜索引擎是如何建立索引的?

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

努力拼搏的80后
03/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周六乱弹 —— 你一口我一口多咬一口是小狗

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @达尔文 :分享Roy Orbison的单曲《She's a Mystery to Me》 《She's a Mystery to Me》- Roy Orbison 手机党少年们想听歌,请使劲儿戳(这里...

小小编辑
今天
31
4
Spring源码学习笔记-1-Resource

打算补下基础,学习下Spring源码,参考书籍是《Spring源码深度解析》,使用版本是Spring 3.2.x,本来想试图用脑图记录的,发现代码部分不好贴,还是作罢,这里只大略记录下想法,不写太细了 ...

zypy333
今天
12
0
RestClientUtil和ConfigRestClientUtil区别说明

RestClientUtil directly executes the DSL defined in the code. ConfigRestClientUtil gets the DSL defined in the configuration file by the DSL name and executes it. RestClientUtil......

bboss
今天
19
0

中国龙-扬科
昨天
4
0
Linux系统设置全局的默认网络代理

更改全局配置文件/etc/profile all_proxy="all_proxy=socks://rahowviahva.ml:80/"ftp_proxy="ftp_proxy=http://rahowviahva.ml:80/"http_proxy="http_proxy=http://rahowviahva.ml:80/"......

临江仙卜算子
昨天
13
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部