Java HashMap排序

简介: HashMap排序可以分为按键排序与按值排序两种,实现思路是先转为List容器,再重写比较函数,调用java内置排序算法即可。

HashMap排序可以分为按键排序与按值排序两种,实现思路是先转为List容器,再重写比较函数,调用java内置排序算法即可。

示例代码如下(使用时根据需要修改map容器类型):

        HashMap<String, Double> map = new HashMap<String, Double>();
		map.put("key1", Math.random() * 100);
		map.put("key4", Math.random() * 100);
		map.put("key3", Math.random() * 100);
		map.put("key5", Math.random() * 100);
		map.put("key2", Math.random() * 100);
		
		List<Map.Entry<String, Double>> mapList = 
				new ArrayList<Map.Entry<String, Double>>(map.entrySet()); 
		
//		排序前打印
		System.out.println("排序前");
		for (Map.Entry<String, Double> entry : mapList) {
			System.out.println(entry.toString());
		}
		System.out.println();

		Collections.sort(mapList, new Comparator<Map.Entry<String, Double>>() {
			public int compare(Map.Entry<String, Double> obj1, Map.Entry<String, Double> obj2) {
				// 请使用内置比较函数, 否则可能会报错, 违反使用约定
				// 具体要满足交换律, 即返回值compare(x, y)与compare(y, x)应一致
				return obj1.getValue().compareTo(obj2.getValue()); // 比较map值
//				return obj1.getKey().compareTo(obj2.getKey()); // 比较map键
			}
		});
		
//		排序后打印
		System.out.println("排序后");
		for (Map.Entry<String, Double> entry : mapList) {
			System.out.println(entry.toString());
		}
按值排序结果:

排序前
key1=40.189446938991416
key2=97.14547760681302
key5=39.86978413432413
key3=44.246717054280374
key4=65.19003398617575

排序后
key5=39.86978413432413
key1=40.189446938991416
key3=44.246717054280374
key4=65.19003398617575
key2=97.14547760681302


按键排序结果:

排序前
key1=71.17675919899192
key2=88.06383506265738
key5=17.37417655482928
key3=1.89149771013285
key4=72.09130459451002

排序后
key1=71.17675919899192
key2=88.06383506265738
key3=1.89149771013285
key4=72.09130459451002
key5=17.37417655482928


目录
相关文章
|
3月前
|
存储 安全 Java
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
64 3
|
4月前
|
Java
Java之HashMap详解
本文介绍了Java中HashMap的源码实现(基于JDK 1.8)。HashMap是基于哈希表的Map接口实现,允许空值和空键,不同步且线程不安全。文章详细解析了HashMap的数据结构、主要方法(如初始化、put、get、resize等)的实现,以及树化和反树化的机制。此外,还对比了JDK 7和JDK 8中HashMap的主要差异,并提供了使用HashMap时的一些注意事项。
186 2
Java之HashMap详解
|
1月前
|
存储 缓存 安全
Java HashMap详解及实现原理
Java HashMap是Java集合框架中常用的Map接口实现,基于哈希表结构,允许null键和值,提供高效的存取操作。它通过哈希函数将键映射到数组索引,并使用链表或红黑树解决哈希冲突。HashMap非线程安全,多线程环境下需注意并发问题,常用解决方案包括ConcurrentHashMap和Collections.synchronizedMap()。此外,合理设置初始化容量和加载因子、重写hashCode()和equals()方法有助于提高性能和避免哈希冲突。
62 17
Java HashMap详解及实现原理
|
5月前
|
存储 Java
Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。
【10月更文挑战第19天】本文详细介绍了Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。HashMap以其高效的插入、查找和删除操作著称,而TreeMap则擅长于保持元素的自然排序或自定义排序,两者各具优势,适用于不同的开发场景。
70 1
|
5月前
|
存储 安全 Java
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
119 2
|
5月前
|
存储 Java 开发者
Java Map实战:用HashMap和TreeMap轻松解决复杂数据结构问题!
【10月更文挑战第17天】本文深入探讨了Java中HashMap和TreeMap两种Map类型的特性和应用场景。HashMap基于哈希表实现,支持高效的数据操作且允许键值为null;TreeMap基于红黑树实现,支持自然排序或自定义排序,确保元素有序。文章通过具体示例展示了两者的实战应用,帮助开发者根据实际需求选择合适的数据结构,提高开发效率。
137 2
|
5月前
|
存储 缓存 安全
HashMap VS TreeMap:谁才是Java Map界的王者?
HashMap VS TreeMap:谁才是Java Map界的王者?
207 2
|
2月前
|
Java 程序员
Java 排序神器:Comparable 和 Comparator 该怎么选?
嗨,大家好,我是小米!今天和大家聊一聊Java社招面试中常考的经典问题——Comparable和Comparator的区别。Comparable定义对象的自然排序,适用于单一固定的排序规则;Comparator则是策略接口,用于定义自定义排序规则,适用于多样化或多变的排序需求。掌握这两者的区别是理解Java排序机制的基础,也是面试中的加分题。结合实际项目场景深入探讨它们的应用,能更好地打动面试官。如果你觉得有帮助,欢迎点赞、收藏、分享,期待你的一键三连!我们下期见~ 我是小米,一个喜欢分享技术的程序员,关注我的微信公众号“软件求生”,获取更多技术干货!
54 20
|
5月前
|
Java
用java搞定时任务,将hashmap里面的值存到文件里面去
本文介绍了如何使用Java的`Timer`和`TimerTask`类创建一个定时任务,将HashMap中的键值对写入到文本文件中,并提供了完整的示例代码。
60 1
用java搞定时任务,将hashmap里面的值存到文件里面去
|
5月前
|
存储 Java 程序员
Java面试加分点!一文读懂HashMap底层实现与扩容机制
本文详细解析了Java中经典的HashMap数据结构,包括其底层实现、扩容机制、put和查找过程、哈希函数以及JDK 1.7与1.8的差异。通过数组、链表和红黑树的组合,HashMap实现了高效的键值对存储与检索。文章还介绍了HashMap在不同版本中的优化,帮助读者更好地理解和应用这一重要工具。
159 5