这篇文章运用简单易懂的例子给大家介绍Java中Map的使用方法,代码非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
在JAVA中,map接口提供的集合又称为查找表。
Map 接口定义的集合又称为查找表,用于存储所谓"key-value"映射对。Key可以看成是Value 的索引,作为key的对象在集合中不可重复。
根据内部数据结构的不同,Map 接口有多种实现类,其中常用的有内部为hash 表实现的 HashMap 和内部为排序二叉树实现的TreeMap。
java.util.Map 接口 查找表
Map 体现的结构是一个多行两列的表格,左列称为key 右列称为value. Map 总是根据key来获取对应的value.因此保存数据时是成对保存的,并且应当将查询的数据作为value查询条件作为key进行保存. Map要求key 不允许重复(equals 比较判定)
常用的实现类
java.util.HashMap,散列表,哈希表
查询速度最快的数据结构
Map的遍历
import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; import java.util.Set; /** * Map的遍历 Map提供了三种遍历方式: 1:遍历所有的key 2:遍历每一组键值对 3:遍历所有的value(相对不常用) * */ public class MapDemo2 { public static void main(String[] args) { Map<String, Integer> map = new HashMap<>(); map.put("语文", 99); map.put("数学", 98); map.put("英语", 97); map.put("物理", 96); map.put("化学", 99); System.out.println(map); /* * 遍历所有的key * Set keySet() * 将当前Map中所有的key以一个Set集合 * 形式返回.遍历该集合等同于遍历了所有 * 的key */ Set<String> keySet = map.keySet(); for(String key : keySet) { System.out.println("key:"+key); } /* * 遍历每一组键值对 * Set entrySet() * 将当前Map中每一组键值对以一个Entry实例 * 存入Set集合并返回. * * java.util.Map.Entry * Entry的每一个实例用于表示Map中的一组 * 键值对 */ Set<Entry<String,Integer>> entrySet = map.entrySet(); for(Entry<String,Integer> e:entrySet) { String key = e.getKey(); Integer value = e.getValue(); System.out.println(key+":"+value); } } }
基本用法
public class MapDemo{ public static void main(String[] args){ Map<String,Integer>map = new HashMap<>(); /* * V put(K k,V v) * 将给定的key-value对存入Map * 由于Map要求key不允许重复,所以若 * 使用重复的key存储则是替换value操作 * 那么返回值就是该key原来对应的value * 若给定的key不存在则返回值为null. */ map.put("攻击",60); Integer value=map.put("攻速",8); System.out.println(value); // null value=map.put("攻速",6); System.out.println(value); // 8 /* * V get(Object key) * 根据给定的key获取对应的value * 若给定的key不存在则返回值为null */ value =map.get("攻击"); System.out.println(value);//60 /* * V remove(Object key) * 删除当前Map中给定的key所对应的键值对 * 返回值为该key对应的value */ value = map.remove("攻击"); System.out.println(map); System.out.println(value); /* * int size() * 返回Map中的元素个数 */ int size = map.size(); System.out.println(size); /* * 判断当前Map是否包含给定的key或value */ boolean ck = map.containsKey("攻速"); System.out.println("包含key:"+ck); boolean cv = map.containsValue(96); System.out.println("包含value:"+cv); } }
关于Java中Map的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。