Java中Map根据键值(key)或者值(value)进行排序实现

我们都知道,java中的Map结构是key->value键值对存储的,而且根据Map的特性,同一个Map中 不存在两个Key相同的元素,而value不存在这个限制。换句话说,在同一个Map中Key是唯一的,而value不唯一。Map是一个接口,我们不能 直接声明一个Map类型的对象,在实际开发中,比较常用的Map性数据结构是HashMap和TreeMap,它们都是Map的直接子类。如果考虑到存取 效率的话,建议使用HashMap数据结构,而如果需要考虑到Key的顺序,建议使用TreeMap,但是TreeMap在删除、添加过程中需要排序,性能比较差。

    1. 以Key进行排序
      我们可以声明一个TreeMap对象

      Map<Integer, Person> map = new TreeMap<Integer, Person>();

      然后往map中添加元素,可以通过输出结果,可以发现map里面的元素都是排好序的

      //遍历集合

      for (Iterator<Integer> it = map.keySet().iterator(); it.hasNext();) {

          Person person = map.get(it.next());

          System.out.println(person.getId_card() + " " + person.getName());

      }

      我们也可以声明一个HashMap对象,然后把HashMap对象赋值给TreeMap,如下:

      Map<Integer, Person> map = new HashMap<Integer, Person>();

      TreeMap treemap = new TreeMap(map);

    2. 以Value进行排序
      先声明一个HashMap对象:

      Map<String, Integer> map = new HashMap<String, Integer>();

      然后我们可以将Map集合转换成List集合中,而List使用ArrayList来实现如下:

      List<Entry<String,Integer>> list =

          new ArrayList<Entry<String,Integer>>(map.entrySet());

      最后通过Collections.sort(List l, Comparator c)方法来进行排序,代码如下:

      Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() {

          public int compare(Map.Entry<String, Integer> o1,

                  Map.Entry<String, Integer> o2) {

              return (o2.getValue() - o1.getValue());

          }

      });

      上述代码是讲map中的value按照逆序排序,如果需要按照升序进行排序的话,只需要修改o2.getValue() - o1.getValue()为o1.getValue() - o2.getValue()即可

时间: 2024-10-05 23:56:41

Java中Map根据键值(key)或者值(value)进行排序实现的相关文章

java中map插入相同的key

测试用例: package test; import org.junit.Test; import po.Person; import java.util.HashMap; import java.util.IdentityHashMap; import java.util.Map; /** * Created by Administrator on 2015/9/16. */ public class TestMap { /** * map插入相同key问题,value会不会覆盖 */ @Te

java中map有哪些

java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复. Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度,遍历时,取得数据的顺序是完全随机的.HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null;

java中Map,List与Set的区别

java中Map,List与Set的区别 目录(?)[+] Set,List,Map的区别 java集合的主要分为三种类型: Set(集) List(列表) Map(映射) 要深入理解集合首先要了解下我们熟悉的数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),而JAVA集合可以存储和操作数目不固定的一组数据. 所有的JAVA集合都位于 java.util包中! JAVA集合只能存放引用类型的的数据,不能存放基本数据类型. 简单说下集合和数组的区别:(参考文章:

探究Java中Map类

Map以按键/数值对的形式存储数据,和数组非常相似,在数组中存在的索引,它们本身也是对象.       Map的接口       Map---实现Map       Map.Entry--Map的内部类,描述Map中的按键/数值对.       SortedMap---扩展Map,使按键保持升序排列           关于怎么使用,一般是选择Map的子类,而不直接用Map类.       下面以HashMap为例.       public     static     void     ma

Java中Map相关的快速查找算法与唯一性(转载)

原文地址:http://blog.csdn.net/chuyuqing/article/details/19629229 在对<Set和hashCode()>的一篇原创文章写完后,由于对自己的一些论断产生了模糊和怀疑,因此又对Set进行了一些研究,形成本篇. 在Set的使用场景中,我们不外乎看中了她存储数据的唯一性,即不能存储重复值,这在某些应用场合下是很必要的一个特性.那么从更深一层来考虑,Set究竟如何使数据不重复的呢?从另一个层面来考虑,她又如何确保在验证数据是否重复过程中的快速性呢?假

(原创) cocos2d-x 3.0+ lua 学习和工作(4) : 公共函数(5): 返回指定表格中的所有键(key):table.keys

这里的函数主要用来做:返回指定表格中所有的键.参考资料为quick_cocos. 星月倾心贡献~~~ --[[ -- 返回指定表格中的所有键(key) -- example: local t = ( a = 1, b = 2, c = 3 ) local keys = table.keys( t ) -- keys = { "a", "b", "c" } -- @param t 要检查的表格(t表示是table) -- @param table

java中map类使用

Map以按键/数值对的形式存储数据,和数组非常相似,在数组中存在的索引,它们本身也是对象.      Map的接口      Map---实现Map      Map.Entry--Map的内部类,描述Map中的按键/数值对.      SortedMap---扩展Map,使按键保持升序排列         关于怎么使用,一般是选择Map的子类,而不直接用Map类.      下面以HashMap为例.      public     static     void     main(Strin

Java中Map接口的遍历

package Test4; import java.util.Collection;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set; import org.junit.Test; public class MapBianLi { /* * 如何遍历Map * Set keySet()-->遍历Key * Collection values()-->遍历va

java中map集合的迭代

import java.util.HashMap; import java.util.Iterator; import java.util.Map; public class TestMap { public static void main(String[] args) { Map<Integer, String> map = new HashMap<Integer, String>(); map.put(1, "a"); map.put(2, "b