Collections.sort()对HashMap里的键值对按照键进行排序

简介: MainActivity如下: package cn.testhashmapsort;import java.util.ArrayList;import java.

MainActivity如下:

package cn.testhashmapsort;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.os.Bundle;
import android.app.Activity;
/**
 * Demo描述:
 * 利用Collections.sort对HashMap里的键值对按照键进行排序
 */
public class MainActivity extends Activity {
    private HashMap<String, Integer> mHashMap;
    private List<Map.Entry<String, Integer>> mHashMapEntryList;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
    private void init(){
    	mHashMap=new HashMap<String, Integer>();
    	mHashMap.put("a", 9527);
    	mHashMap.put("z", 7);
    	mHashMap.put("c", 888);
    	mHashMap.put("x", 666);
    	mHashMapEntryList=new ArrayList<Map.Entry<String,Integer>>(mHashMap.entrySet());
    	
    	System.out.println("-----> 排序前的顺序");
    	for (int i = 0; i < mHashMapEntryList.size(); i++) {
			 System.out.println(mHashMapEntryList.get(i));
		}
    	
    	Collections.sort(mHashMapEntryList, new Comparator<Map.Entry<String,Integer>>() {

			@Override
			public int compare(Map.Entry<String,Integer> firstMapEntry, 
					           Map.Entry<String,Integer> secondMapEntry) {
				return firstMapEntry.getKey().compareTo(secondMapEntry.getKey());
			}
		});
    	
    	System.out.println("-----> 排序后的顺序");
    	for (int i = 0; i < mHashMapEntryList.size(); i++) {
			 System.out.println(mHashMapEntryList.get(i));
		}
    }

}


main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >

    <TextView
        android:layout_centerInParent="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="测试HashMap的排序" 
        android:textSize="20sp"
        />

</RelativeLayout>


 

相关文章
|
存储 安全 Java
深入理解HashMap:Java中的键值对存储利器
深入理解HashMap:Java中的键值对存储利器
259 0
|
搜索推荐 Java API
一道Java集合排序题,HashMap排序,面试必备
一道Java集合排序题,HashMap排序,面试必备
129 0
|
11月前
|
存储 安全 数据库
除了 HashMap,还有哪些数据结构可以实现键值对存储?
【10月更文挑战第11天】 除了`HashMap`,其他常见支持键值对存储的数据结构包括:`TreeMap`(基于红黑树,键有序)、`LinkedHashMap`(保留插入顺序)、`HashTable`(线程安全)、`B-Tree`和`B+Tree`(高效存储大量数据)、`SkipList`(通过跳跃指针提高查找效率)及`UnorderedMap`(类似`HashMap`)。选择合适的数据结构需根据排序、并发、存储和查找性能等需求。
|
存储 算法 Java
Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。
【6月更文挑战第21天】Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。简单哈希表实现未涵盖冲突解决和删除操作。
162 1
java使用HashMap对文件进行排序并输出
java使用HashMap对文件进行排序并输出
|
存储 缓存 安全
【JavaSE专栏53】Java集合类HashMap解析,基于哈希表的键值对存储结构
【JavaSE专栏53】Java集合类HashMap解析,基于哈希表的键值对存储结构
215 0
|
Java
Java——HashMap键值排序
Java——HashMap键值排序
491 0