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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java:如何判断一个Map中的某个key是不是在另一个Map的key列表中相关的知识,希望对你有一定的参考价值。

Map<T> map2 = new HashMap<T>();
boolean flag = map2.containsKey(Object key);可以看到一个map集合中是否包含特定的key
参考技术A //判断map1中的key时候出现在map2中,出现的存入list集合中
List<Object> list = new ArrayList<Object>();
Map<Object,Object> map1 = new HashMap<Object,Object>();
Map<Object,Object> map2 = new HashMap<Object,Object>();
Set<Object> set1 =map1.keySet();
Iterator<Object> it = set1.iterator();
while(it.hasNext())
Object obj = it.next();
if(map2.containsKey(obj))
list.add(obj);

本回答被提问者和网友采纳

java之map集合

如果程序中存储了几百万个学生,而且经常需要使用学号来搜索某个学生,那么这个需求有效的数据结构就是MapMap是一种依照键(key)存储元素的容器,键(key)很像下标,在List中下标是整数。在Map中键(key)可以使任意类型的对象。Map中不能有重复的键(Key),每个键(key)都有一个对应的值(value)。一个键(key)和它对应的值构成map集合中的一个元素。

Map中的元素是两个对象,一个对象作为键,一个对象作为值。键不可以重复,但是值可以重复。

看顶层共性方法找子类特有对象.

 

 

interface Map<K,V>

K - 此映射所维护的键的类型

V - 映射值的类型

概念

将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。

特点

KeyValue1对1的关系,如:门牌号 :家  老公:老婆

双列集合

 

 ---| Map  接口    将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。

 

---| HashMap  采用哈希表实现,所以无序

 

            ---| TreeMap   可以对健进行排序

 

---|Hashtable:

 

底层是哈希表数据结构,线程是同步的,不可以存入null键,null值。

 

效率较低,被HashMap 替代。

 

---|HashMap:

 

底层是哈希表数据结构,线程是不同步的,可以存入null键,null值。

 

要保证键的唯一性,需要覆盖hashCode方法,和equals方法。

 

---| LinkedHashMap

 

该子类基于哈希表又融入了链表。可以Map集合进行增删提高效率。

 

---|TreeMap:

 

底层是二叉树数据结构。可以对map集合中的键进行排序。需要使用Comparable或者Comparator 进行比较排序。return 0,来判断键的唯一性。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

总结:

Map与Collection在集合框架中属并列存在,

1.Map存储的是键值对,

2..Map存储元素使用put方法,Collection使用add方法

3..Map集合没有直接取出元素的方法,而是先转成Set集合,在通过迭代获取元素

4..Map集合中键要保证唯一性

5..也就是Collection是单列集合, Map 是双列集合。

 

Map一次存一对元素, Collection 一次存一个。Map 的键不能重复,保证唯一。

Map 一次存入一对元素,是以键值对的形式存在.键与值存在映射关系.一定要保证键的唯一性.

以上是关于Java:如何判断一个Map中的某个key是不是在另一个Map的key列表中的主要内容,如果未能解决你的问题,请参考以下文章

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

JAVA怎样判断一个对象的类型

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

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

java 判断map是否存在某个key 和 json字符串转化为list对象

java map表里,key值能否映射到多个Value?