hashmap的排序方式,hashmap排序hashmap根据value排序
目录
简介排序已有数据按键排序按价值排序按插入顺序存放模拟不按插入顺序存放LinkedHashMap会按照插入顺序存放
简介
本文用示例介绍模拟排序的方法。
排序已有数据
按key排序
使用stream进行排序(按key升序/降序)
包org。举例。a;导入Java。util。*;public class Demo { public static void main(String[]args){ MapString,String map=new HashMap();map.put(ad , DD );map.put(bc , ee );map.put(cb , ff );对于(图EntryString,字符串条目:映射。entry set()){ system。出去。println(条目。getkey()“:”条目。getvalue());}系统。出去。println();MapString,String linked hashmap=new linked hashmap();//默认按照升序排列map.entrySet().流()。已排序(地图Entry.comparingByKey())。forEach(o-linked hashmap。put(o . getkey()、o . getvalue());对于(图EntryString,字符串条目:链接hashmap。entry set()){ system。出去。println(条目。getkey()“:”条目。getvalue());}系统。出去。println();MapString,String linked hashmap 1=new linked hashmap();//自定义排序(降序)map.entrySet().流()。已排序(地图10 .入口。comparingbykey(new comparator String(){ @ Override public int compare(String O1,String O2){ return O2。与(O1)比较;} })).forEach(o-linked hashmap 1。put(o . getkey()、o . getvalue());对于(图EntryString,字符串条目:链接hashmap 1。entry set()){ system。出去。println(条目。getkey()“:”条目。getvalue());} }}执行结果
公元前:年eead :年ddcb :年ffad :年ddbc :年eecb :年ffcb :年ffbc :年
HashMap转TreeMap自定义排序(按key升序/降序)
包org。举例。a;导入Java。util。比较器;导入Java。util。hashmap导入Java。util。地图;导入Java。util。树形图;public class Demo { public static void main(String[]args){ MapString,String map=new HashMap();map.put(ad , DD );map.put(bc , ee );map.put(cb , ff );
for (Map.Entry<String, String> entry : map.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } System.out.println(); // 默认按照升序排序 Map<String, String> map1 = new TreeMap<>(); map.forEach(map1::put); for (Map.Entry<String, String> entry : map1.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } System.out.println(); // 自定义排序(降序) Map<String, String> map2 = new TreeMap<>(new Comparator<String>() { @Override public int compare(String o1, String o2) { return o2.compareTo(o1); } }); map.forEach(map2::put); for (Map.Entry<String, String> entry : map2.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } }}执行结果
bc:eead:ddcb:ffad:ddbc:eecb:ffcb:ffbc:eead:dd
按value排序
使用stream进行排序(按value升序/降序)
package org.example.a; import java.util.*; public class Demo { public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map.put("ad", "dd"); map.put("bc", "ee"); map.put("cb", "ff"); for (Map.Entry<String, String> entry : map.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } System.out.println(); Map<String, String> linkedHashMap = new LinkedHashMap<>(); // 默认按照升序排列 map.entrySet().stream().sorted(Map.Entry.comparingByValue()) .forEach(o -> linkedHashMap.put(o.getKey(), o.getValue())); for (Map.Entry<String, String> entry : linkedHashMap.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } System.out.println(); Map<String, String> linkedHashMap1 = new LinkedHashMap<>(); // 自定义排序(降序) map.entrySet().stream().sorted(Map.Entry.comparingByValue(new Comparator<String>() { @Override public int compare(String o1, String o2) { return o2.compareTo(o1); } })).forEach(o -> linkedHashMap1.put(o.getKey(), o.getValue())); for (Map.Entry<String, String> entry : linkedHashMap1.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } }}
执行结果
bc:eead:ddcb:ffad:ddbc:eecb:ffcb:ffbc:eead:dd
借助List进行排序(按value升序/降序)
原理:将待排序Map中的所有元素置于一个列表中,接着使用Collections的一个静态方法 sort(List<T> list, Comparator<? super T> c) 来排序列表,同样是用比较器定义比较规则。排序后的列表中的元素再依次装入Map,为了肯定的保证Map中元素与排序后的List中的元素的顺序一致,使用了LinkedHashMap数据类型。
本处只写升序代码,降序只是调换个顺序而已。
package org.example.a; import java.util.*; public class Demo { public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map.put("ad", "dd"); map.put("bc", "ee"); map.put("cb", "ff"); for (Map.Entry<String, String> entry : map.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } System.out.println(); Map<String, String> sortedMap = new LinkedHashMap<>(); List<Map.Entry<String, String>> entryList = new ArrayList<Map.Entry<String, String>>( map.entrySet()); Collections.sort(entryList, new Comparator<Map.Entry<String, String>>() { @Override public int compare(Map.Entry<String, String> me1, Map.Entry<String, String> me2) { return me1.getValue().compareTo(me2.getValue()); } }); for (Map.Entry<String, String> stringStringEntry : entryList) { sortedMap.put(stringStringEntry.getKey(), stringStringEntry.getValue()); } for (Map.Entry<String, String> entry : sortedMap.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } }}
运行结果
bc:eead:ddcb:ffad:ddbc:eecb:ff
按插入顺序存放
HashMap不按插入顺序存放
package org.example.a; import java.util.*; public class Demo{ public static List arrayList = new ArrayList(); public static void main(String[] args) { Map<String, String> hashMap = new HashMap<String, String>(); hashMap.put("name1", "josan1"); hashMap.put("name2", "josan2"); hashMap.put("name3", "josan3"); Set<Map.Entry<String, String>> set = hashMap.entrySet(); Iterator<Map.Entry<String, String>> iterator = set.iterator(); while(iterator.hasNext()) { Map.Entry entry = iterator.next(); String key = (String) entry.getKey(); String value = (String) entry.getValue(); System.out.println("key:" + key + ", value:" + value); } }}
执行结果(未按照插入顺序输出)
key:name3, value:josan3key:name2, value:josan2key:name1, value:josan1
LinkedHashMap会按照插入顺序存放
package org.example.a; import java.util.*; public class Demo{ public static List arrayList = new ArrayList(); public static void main(String[] args) { Map<String, String> hashMap = new LinkedHashMap<String, String>(); hashMap.put("name1", "josan1"); hashMap.put("name2", "josan2"); hashMap.put("name3", "josan3"); Set<Map.Entry<String, String>> set = hashMap.entrySet(); Iterator<Map.Entry<String, String>> iterator = set.iterator(); while(iterator.hasNext()) { Map.Entry entry = iterator.next(); String key = (String) entry.getKey(); String value = (String) entry.getValue(); System.out.println("key:" + key + ", value:" + value); } }}
执行结果(按照插入顺序输出)
key:name1, value:josan1key:name2, value:josan2key:name3, value:josan3
以上就是Java实现HashMap排序方法的示例详解的详细内容,更多关于Java HashMap排序的资料请关注盛行IT其它相关文章!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。