这篇文章运用简单易懂的例子给大家介绍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的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。