Java集合之HashMap用法详解
2017-05-12 10:45
781 查看
本文实例讲述了Java集合之HashMap用法。分享给大家供大家参考,具体如下:
HashMap是最常用的Map集合,它的键值对在存储时要根据键的哈希码来确定值放在哪里。
HashMap 中作为键的对象必须重写Object的
hashCode()方法和
equals()方法
import java.util.Map; import java.util.HashMap; public class lzwCode { public static void main(String [] args) { Map<Integer, String> map = new HashMap<Integer, String>(); map.put(1, "Barcelona"); map.put(2, "RealMadrid"); map.put(3, "ManchesterUnited"); map.put(4, "AC milan"); map.put(5, null); map.put(null, null); //map.put(null, "Chelsea"); //可以运行键值都为空(如果键相同,后者覆盖前者) System.out.println(map); System.out.print(map.keySet()+" "); //集合中所有键以Set集合形式返回 System.out.println(); System.out.print(map.values()+" "); //集合中所有键以Collection集合形式返回 System.out.println(); System.out.println("集合大小:"+map.size()); System.out.println("是否包含该键:"+map.containsKey(2));//返回boolean System.out.println("是否包含该值:"+map.containsValue("Barcelona"));//返回boolean System.out.println(map.isEmpty()); //不包含键-值映射关系,则返回true map.remove(5); //删除映射关系 System.out.println(map); map.clear();//清空集合 System.out.println(map); } }
控制台结果:
HashMap的两种遍历方法
import java.util.Map; import java.util.HashMap; import java.util.Iterator; public class lzwCode { public static void main(String [] args) { Map<String, Integer> map = new HashMap<String, Integer>(); map.put("Barcelona", 1); map.put("RealMadrid", 2); map.put("ManchesterUnited", 3); map.put("AC milan", 4); map.put("Chelsea", 5); //第一种:(效率高) System.out.println("第一种方法:"); Iterator iter = map.entrySet().iterator(); while (iter.hasNext()) { Map.Entry entry = (Map.Entry)iter.next(); Object key = entry.getKey(); Object val = entry.getValue(); System.out.println("键:"+key+"<==>"+"值:"+val); } //第二种:(效率低) System.out.println("第二种方法:"); Iterator it = map.keySet().iterator(); while (it.hasNext()) { Object key = it.next(); Object val = map.get(key); System.out.println("键:"+key+"<==>"+"值:"+val); } //对于keySet只是遍历了2次,一次是转为iterator,一次就从HashMap中取出key所对于的value。 //对于entrySet只是遍历了第一次,它把key和value都放到了entry中,所以快比keySet快些。 System.out.println("For-Each循环输出"); //For-Each循环 for (Map.Entry<String, Integer> entry:map.entrySet()) { String key = entry.getKey().toString(); String val = entry.getValue().toString(); System.out.println("键:"+key+"<==>"+"值:"+val); } } }
控制台结果:
PS:这里再为大家提供2款hash相关在线工具供大家参考使用:
在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
您可能感兴趣的文章:
- 基于Java中最常用的集合类框架之HashMap(详解)
- Java集合框架源码分析之LinkedHashMap详解
- Java concurrency集合之ConcurrentHashMap_动力节点Java学院整理
- Java中HashMap和TreeMap的区别深入理解
- JAVA HashMap详细介绍和示例
- 浅析Java中Map与HashMap,Hashtable,HashSet的区别
- java HashMap通过value反查key的代码示例
- Java中HashMap和Hashtable及HashSet的区别
- java中Hashtable和HashMap的区别分析
- Java集合系列之HashMap源码分析
相关文章推荐
- Java hashset hashmap用法机制详解
- 关于java的集合类,以及HashMap中Set的用法
- java中hashcode与equals详解(集合中的用法)
- Java集合2-HashMap详解(含源码分析)
- 关于java的集合类,以及HashMap中Set的用法!
- java集合中HashMap原理详解
- JAVA常用集合框架用法详解基础篇三之Colletion子接口Set
- 关于java的集合类,以及HashMap中Set的用法!
- 关于java的集合类,以及HashMap中Set的用法!
- Java集合基础篇(4)-HashMap基本用法
- java集合第八章WeakHashMap的用法
- Java集合:HashMap使用详解及源码分析
- JAVA常用集合框架用法详解——基础篇
- java集合13--WeakHashMap源码详解
- java_集合体系之HashMap详解、源码及示例——09
- java第八章集合中的IdentityHashMap的用法
- JAVA常用集合框架用法详解——提高篇
- JAVA学习【8】集合框架HashMap、TreeMap的基本用法
- 【java】java集合list与set、map集合的区别、用法详解
- java集合中HashMap原理详解