java map 判断有没有key

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java map 判断有没有key相关的知识,希望对你有一定的参考价值。

参考技术A String key="keyname";
boolean flag=map.containsKey(key);本回答被提问者采纳
参考技术B 为何不看JDK的 API文档呢

~
~
~

Java集合--Map

Map接口(双例集合):

  Map提供了映射关系,存放的元素是以key-value键值对存放的。可以根据key快速的查询value。key不可以重复,value可以重复。

常用实现类:HashMap,Hashtable,LinkedHashMap,TreeMap

常用方法
判断功能
boolean isEmpty():判断map是否为空
boolean containsKey(Object key):判断是否包含某个key
boolean containsValue(Object value):判断是否包含某个value
 
获取功能
int size():返回键值对的个数
V get(Object key):返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null
Set<K> keySet():返回此映射中包含的键的 Set 视图
Collection<V> values():返回此映射中包含的值的 Collection 视图
Set<Map.Entry<K, V>> entrySet():返回此映射中包含的映射关系的 Set 视图
 
添加功能
V put(K key, V value):将指定的值与此映射中的指定键关联(可选操作)。如果此映射以前包含一个该键的映射关系,则用指定值替换旧值,并且返回旧的值。否则返回null
void putAll(Map<? extends K, ? extends V> m):把一组键值对放入到Map中。
 
删除功能
V remove(Object key):删除指定的key对应的键值对,返回被删除的键指定的值
void clear():从此映射中移除所有映射关系
 
遍历方式
方式1:根据键找值
获取所有键的集合
遍历键的集合,获取到每一个键
根据键找值
如:
Set<String> keySet = stus.keySet();
for(String key : keySet){
System.out.println(key +": "+stus.get(key));
}
方式2:根据键值对对象找键和值
获取所有键值对对象的集合
遍历键值对对象的集合,获取到每一个键值对对象
根据键值对对象找键和值
Set<Entry<String, String>> entrySet = stus.entrySet();
for(Entry<String, String> entry : entrySet){
System.out.println(entry.getKey()+" : "+entry.getValue());
}
 
HashMap:
特点:
  1. 不保证映射的顺序
  2. 可以使用null作为键或者值
  3. 线程不安全
  4. 底层使用Hash表来存储数据,默认大小16,负载因子0.75,当hash表的容量超过负载因子的时候开始扩容,扩容为原始容量的2
  5. 扩容时机,元素个数超过threshold的时候。
  6. 最多可以存放的元素个数为1<<30
  7. 执行new HashMap()的时候,并没有初始化table;而是在put的时候,才初始化。
  8. 不允许重复的key

LinkedHashMap:

特点:

  1. 可以排序,注意这里所说的顺序并不是添加的顺序。而是从大到小或者从小到大的顺序。
  2. 保证元素的唯一性

Hashtable:

特点:

1、线程安全,效率低
2、不能将null作为键或者值
3、初始容量为11,负载因子为0.75。超过负载因子*容量开始扩容,扩容为旧的容量*2+1
 
 

以上是关于java map 判断有没有key的主要内容,如果未能解决你的问题,请参考以下文章

Java:如何判断一个Map中的某个key是不是在另一个Map的key列表中

java怎么判断map集合的值是多少?

java中怎么判断map的key类型

java map中如何判断key是不是相同

java 多种判断key是否在map中存在的方法

js 中判断字典中是不是有key