/*
* 获取功能:
* V get(Object key):根据键获取值
* Set<K> keySet():获取集合中全部键的集合
* Collection<V> values():获取集合中全部值的集合
*/java
Map<String, String> map = new HashMap<String, String>(); // 建立元素并添加元素 map.put("邓超", "孙俪"); map.put("黄晓明", "杨颖"); map.put("周杰伦", "蔡依林"); map.put("刘恺威", "杨幂"); // V get(Object key):根据键获取值 System.out.println("get:" + map.get("周杰伦")); System.out.println("get:" + map.get("周杰")); // 返回null System.out.println("----------------------"); // Set<K> keySet():获取集合中全部键的集合 Set<String> set = map.keySet(); for (String key : set) { System.out.println(key); } System.out.println("----------------------"); // Collection<V> values():获取集合中全部值的集合 Collection<String> con = map.values(); for (String value : con) { System.out.println(value); }
遍历android
// 遍历 // 获取全部的键 Set<String> set = map.keySet(); // 遍历键的集合,获取获得每个键 for (String key : set) { // 根据键去找值 String value = map.get(key); System.out.println(key + "---" + value); }
另外一种方式遍历ide
Set<Map.Entry<String, String>> set = map.entrySet(); // 遍历键值对对象的集合,获得每个键值对对象 for (Map.Entry<String, String> me : set) { // 根据键值对对象获取键和值 String key = me.getKey(); String value = me.getValue(); System.out.println(key + "---" + value); }
当数据量大的时候,采用entrySet遍历key+value的效率要高于keySet(比较效率https://blog.csdn.net/zhangsify/article/details/52966094)spa
//---------------------------------------------------------------------------------------------------------------------.net
/*
* HashMap:是基于哈希表的Map接口实现。
* 哈希表的做用是用来保证键的惟一性的。
*
* HashMap<String,String>
* 键:String(不容许重复)
* 值:String(容许重复)
*/线程
HashMap<String, String> hm = new HashMap<String, String>(); hm.put("it001", "马云"); hm.put("it003", "马化腾"); hm.put("it004", "乔布斯"); hm.put("it005", "张朝阳"); hm.put("it002", "裘伯君"); // wps hm.put("it001", "比尔盖茨"); // 遍历 Set<String> set = hm.keySet(); for (String key : set) { String value = hm.get(key); System.out.println(key + "---" + value); }
结果code
it004---乔布斯 it003---马化腾 it005---张朝阳 it002---裘伯君 it001---比尔盖茨
这里为何键it001有两个选取最后一个 ,最后一个覆盖前面一个键对象
//================================================================================blog
/*
* LinkedHashMap:是Map接口的哈希表和连接列表实现,具备可预知的迭代顺序。
* 由哈希表保证键的惟一性
* 由链表保证键盘的有序(存储和取出的顺序一致)
*/排序
LinkedHashMap<String, String> hm = new LinkedHashMap<String, String>(); // 建立并添加元素 hm.put("2345", "hello"); hm.put("1234", "world"); hm.put("3456", "java"); hm.put("1234", "javaee"); hm.put("3456", "android"); // 遍历 Set<String> set = hm.keySet(); for (String key : set) { String value = hm.get(key); System.out.println(key + "---" + value); }
TreeMap
TreeMap<Student, String> tm = new TreeMap<Student, String>( new Comparator<Student>() { @Override public int compare(Student s1, Student s2) { // 主要条件 int num = s1.getAge() - s2.getAge(); // 次要条件 int num2 = num == 0 ? s1.getName().compareTo( s2.getName()) : num; return num2; } }); // 建立学生对象 Student s1 = new Student("潘安", 30); Student s2 = new Student("柳下惠", 35); Student s3 = new Student("唐伯虎", 33); Student s4 = new Student("燕青", 32); Student s5 = new Student("唐伯虎", 33); // 存储元素 tm.put(s1, "宋朝"); tm.put(s2, "元朝"); tm.put(s3, "明朝"); tm.put(s4, "清朝"); tm.put(s5, "汉朝"); // 遍历 Set<Student> set = tm.keySet(); for (Student key : set) { String value = tm.get(key); System.out.println(key.getName() + "---" + key.getAge() + "---" + value); }
潘安---30---宋朝 燕青---32---清朝 唐伯虎---33---汉朝 柳下惠---35---元朝
//=========================================
HashMap
LinkedHashMap
TreeMap
使用方式