When learning the usage of map collection in java, I found serveral beneficial methods that was encountered in the daily life. Now  I made a summary:

[java] view
plain
copy

  1. import java.util.ArrayList;
  2. import java.util.Collections;
  3. import java.util.Comparator;
  4. import java.util.HashMap;
  5. import java.util.Iterator;
  6. import java.util.List;
  7. import java.util.Map;
  8. import java.util.SortedMap;
  9. import java.util.TreeMap;
  10. public class MapUtil
  11. {
  12. private static final Map<String, String> contents = new HashMap<String, String>();
  13. @SuppressWarnings("unchecked")
  14. public static void initMap()
  15. {
  16. Map testMap = new HashMap<String, String>();
  17. testMap.put("Albert", "Shao");
  18. contents.putAll(testMap);
  19. }
  20. /**
  21. * Four methods to list map.
  22. * output:
  23. * Albert:Shao
  24. Albert:Shao
  25. Shao
  26. Albert:Shao
  27. * @time Jul 18, 2014 11:39:46 AM
  28. * @return void
  29. */
  30. public static void listMap()
  31. {
  32. Map<String, String> testMap = new HashMap<String, String>();
  33. testMap.put("Albert", "Shao");
  34. for (Map.Entry<String, String> entry : testMap.entrySet())
  35. {
  36. System.out.println(entry.getKey() + ":" + entry.getValue());
  37. }
  38. for (String key : testMap.keySet())
  39. {
  40. System.out.println(key + ":" + testMap.get(key));
  41. }
  42. for (String value : testMap.values())
  43. {
  44. System.out.println(value);
  45. }
  46. Iterator<Map.Entry<String, String>> keyIt = testMap.entrySet()
  47. .iterator();
  48. while (keyIt.hasNext())
  49. {
  50. Map.Entry<String, String> entry = keyIt.next();
  51. System.out.println(entry.getKey() + ":" + entry.getValue());
  52. }
  53. }
  54. /**
  55. * Use the treeMap order by key asc.
  56. * Watch out: if key is repeated, the latter element will replace the former.
  57. * output: {Apple=five, Banana=three, Grape=one, Pair=four}
  58. *
  59. * @time Jul 18, 2014 11:37:51 AM
  60. * @return void
  61. */
  62. public static void sort()
  63. {
  64. SortedMap<String, String> sortMap = new TreeMap<String, String>();
  65. sortMap.put("Pair", "four");
  66. sortMap.put("Apple", "two");
  67. sortMap.put("Grape", "one");
  68. sortMap.put("Banana", "three");
  69. sortMap.put("Apple", "five");
  70. System.out.println(sortMap);
  71. }
  72. /**
  73. * Sort the Map by map.value, then set the result to map.
  74. * output : [Apple=1, Pair=2, Banana=3, Grape=4]
  75. *
  76. * @time Jul 18, 2014 11:36:28 AM
  77. * @return void
  78. */
  79. public static void sortByValue()
  80. {
  81. Map<String, Integer> testMap = new HashMap<String, Integer>();
  82. testMap.put("Pair", 2);
  83. testMap.put("Apple", 1);
  84. testMap.put("Grape", 4);
  85. testMap.put("Banana", 3);
  86. List<Map.Entry<String, Integer>> entryList = new ArrayList<Map.Entry<String, Integer>>(
  87. testMap.entrySet());
  88. Collections.sort(entryList,
  89. new Comparator<Map.Entry<String, Integer>>()
  90. {
  91. public int compare(Map.Entry<String, Integer> c1,
  92. Map.Entry<String, Integer> c2)
  93. {
  94. return (c1.getValue() - c2.getValue());
  95. }
  96. });
  97. System.out.println(entryList);
  98. }
  99. /**
  100. *Sort map by value when value is object.
  101. * use compareTo method to replace simple '-'
  102. * output:[Apple=AB, Grape=AF, Pair=BB, Banana=XY]
  103. *
  104. * @time Jul 18, 2014 11:48:35 AM
  105. * @return void
  106. */
  107. public static void sortByObject()
  108. {
  109. Map<String, String> testMap = new HashMap<String, String>();
  110. testMap.put("Pair", "BB");
  111. testMap.put("Apple", "AB");
  112. testMap.put("Grape", "AF");
  113. testMap.put("Banana", "XY");
  114. List<Map.Entry<String, String>> entryList = new ArrayList<Map.Entry<String, String>>(
  115. testMap.entrySet());
  116. Collections.sort(entryList,
  117. new Comparator<Map.Entry<String, String>>()
  118. {
  119. public int compare(Map.Entry<String, String> c1,
  120. Map.Entry<String, String> c2)
  121. {
  122. return (c1.getValue().compareTo(c2.getValue()));
  123. }
  124. });
  125. System.out.println(entryList);
  126. }
  127. public static void main(String[] args)
  128. {
  129. MapUtil.listMap();
  130. MapUtil.sort();
  131. MapUtil.sortByValue();
  132. MapUtil.sortByObject();
  133. }
  134. }

If you want to further know about the usage of list methods, you could view my another blogs.

http://blog.csdn.net/sxb0841901116/article/details/20635267

【DateStructure】 Charnming usages of Map collection in Java的更多相关文章

  1. 如何用javac 和java 编译运行整个Java工程 (转载)【转】在Linux下编译与执行Java程序

    如何用javac 和java 编译运行整个Java工程 (转载)  http://blog.csdn.net/huagong_adu/article/details/6929817 [转]在Linux ...

  2. 【BZOJ1125】[POI2008]Poc hash+map+SBT

    [BZOJ1125][POI2008]Poc Description n列火车,每条有l节车厢.每节车厢有一种颜色(用小写字母表示).有m次车厢交换操作.求:对于每列火车,在交换车厢的某个时刻,与其颜 ...

  3. 【算法】哈希表的诞生(Java)

    参考资料 <算法(java)>                           — — Robert Sedgewick, Kevin Wayne <数据结构>       ...

  4. 【Unity】Unity中C#与Android中Java的互相调用遇到的一些问题

    1.有关调用的一些问题: (1).在C#中直接调用java中的代码,无返回值: 在java中: public static void setAge(Context context , int leve ...

  5. 【dom4j】解析xml为map

    dom4j解析xml文件 <?xml version="1.0" encoding="utf-8"?> <workflows> < ...

  6. 【python】lamda表达式,map

    一个很好的博客:http://blog.csdn.net/mathboylinlin/article/details/9413551 博客不让转载,我只摘抄了里面几个例子,更多内容到博客里去看 lam ...

  7. 【iOS】苹果,百度Map定位使用与总结

    iOS中使用较多的3款地图,google地图.百度地图.苹果自带地图(高德).当中苹果自带地图在中国使用的是高德的数据.苹果在iOS 6之后放弃了使用谷歌地图,而改用自家的地图.在国内使用的较多的就是 ...

  8. 【原创】【Android】揭秘 ART 细节 ---- Garbage collection

      背景 Dalvik :http://zh.wikipedia.org/wiki/Dalvik%E8%99%9A%E6%8B%9F%E6%9C%BA ART :http://source.andro ...

  9. 【384】reduce归纳、map映射、filter筛选 的用法

    参考:4. Map, Filter and Reduce — Python Tips 0.1 documentation 参考:Python的functools.reduce用法 Map:映射,对于列 ...

随机推荐

  1. 异步操作AsycnTask类

    1.  首先执行onPreExecute方法,进行UI的初步设置 2.  其次执行doInBackground方法,此时将不在UI中线程中进行了 3.  然后如果要进行中的数据的话可以通过publis ...

  2. ceph rpm foor rhel6

    ceph-0.86-0.el6.x86_64.rpm 09-Oct-2014 10:00 13M ceph-0.87-0.el6.x86_64.rpm 29-Oct-2014 13:38 13M ce ...

  3. 合理的keyword密度散布与黑帽SEO之躲藏文本

    合理的keyword密度散布与黑帽SEO之躲藏文本 咱们都晓得.关于baidu的keyword排行有一个非常重要的条件即是keyword密度.在咱们的了解中keyword的密度在2%-8%这个规模之内 ...

  4. 使用Vitamio打造自己的Android万能播放器(1)——准备

    前言 虽然Android已经内置了VideoView组件和MediaPlayer类来支持开发视频播放器,但支持格式.性能等各方面都十分有限,这里与大家一起利用免费的Vitamio来打造属于自己的And ...

  5. HDU 3698 DP+线段树

    给出N*M矩阵.每一个点建立灯塔有花费.每一个点的灯塔有连接范围,求每一行都建立一个灯塔的最小花费,要求每相邻两行的灯塔能够互相连接.满足 |j-k|≤f(i,j)+f(i+1,k) DP思路,dp[ ...

  6. Linux网桥介绍

    网桥的功能类似于二层交换机,作用都是划分冲突域,它们之前且一些细微的差别,此处不展开. Linux网桥作为一个特殊的网桥的实现,有一些自己的特点,因为没有看代码,只能从功能上简单分析一下.个人认为,L ...

  7. 一个很好的用C#导出数据到Excel模板的方法

    /// <summary> /// 导数据到Excel模板 /// </summary> /// <param name="tab">要输出内容 ...

  8. IsPostBack是什么意思,如何运用?

    IsPostBack是Page类的一个属性,返回值为一个布尔值.一般放在Page_Load事件中.当页面是第一次打开时其值为False,若当前页面为一个提交后的页面其值为True. if (!IsPo ...

  9. 望大神批评教育国庆无聊之作:ObjectValidator

    起因: 本人国庆无聊,不知道干嘛, 所以模仿FluentValidation写了个简化版的ObjectValidator 个人设想是能用类似fluent的方式创建验证规则,然后使用者缓存并验证自己的对 ...

  10. DooDigestAuth php(后台)授权管理类 web浏览器授权

    <?php /** * DooDigestAuth class file. * * @author Leng Sheng Hong <darkredz@gmail.com> * @l ...