【Java集合框架】篇五:Map接口
创始人
2024-05-28 11:21:55

1. Map及实现类特点

Map:存储key-value

  • HashMap:线程不安全,效率高,key和value都可以为null,底层使用 数组+单向链表+红黑树 结构(jdk8)。
    • LinkedHashMap:是HashMap的子类,在HashMap结构的基础上增加了一对双向链表,用于记录添加元素的先后顺序,便于遍历操作,开发中,对于频繁的遍历操作,建议使用此类。
  • Hashtable:古老实现类,线程安全,效率低,key和value都不可以为null,底层使用 数组+单向链表 结构存储(jdk8)。
    • Properties:是Hashtable的子类,其key和value都是String类型,常用来处理属性文件。将某些数据和代码分离,程序执行前会先读取该配置文件。
  • TreeMap:底层使用红黑树存储,可以按照添加key-value中的key元素指定规则进行遍历。考虑使用:自然排序、定制排序。

2. HashMap中元素的特点

  1. HashMap中的所有key之间是无序的、不可重复的。所有key就构成了一个Set集合。—>因而key所在类要重写hashCode()和equals()方法。
  2. HashMap中所有的value之间是无序的、可重复的。所有的value就构成了一个Collection集合。—>因而value所在类要重写equals()方法。
  3. HashMap中的一对key-value,构成了一个Entry对象。
  4. HashMap中的所有Entry对象之间是无序的、不可重复的。所有的Entry对象就构成了一个Set集合。

3. Map中的常用方法

添加、修改操作:

添加、修改使用的方法一样

  • Object put(Object key,Object value):将指定key-value添加到(或修改)当前map对象中
  • void putAll(Map m):将m中的所有key-value对存放到当前map中

删除操作:

  • Object remove(Object key):移除指定key的key-value对,并返回value
  • void clear():清空当前map中的所有数据

元素查询的操作:

  • Object get(Object key):获取指定key对应的value
  • boolean containsKey(Object key):是否包含指定的key
  • boolean containsValue(Object value):是否包含指定的value
  • int size():返回map中key-value对的个数
  • boolean isEmpty():判断当前map是否为空
  • boolean equals(Object obj):判断当前map和参数对象obj是否相等

元视图操作的方法(遍历):

  • Set keySet():返回所有key构成的Set集合
  • Collection values():返回所有value构成的Collection集合
  • Set entrySet():返回所有key-value对构成的Set集合

相关内容

热门资讯

【应用】阿里推出夸克网盘独立A... 记得之前调研大家都在用哪家浏览器的时候,提名夸克的非常多,但不知道这些用夸克的小伙伴里有多少有使用夸...
王楚钦战胜张本智和,夺得乒乓球... 转自:央视新闻客户端在今天进行的第35届国际乒联-亚乒联盟亚洲杯男单决赛中,王楚钦战胜日本选手张本智...
调研速递|丽珠集团接受摩根基金... 2月6日,丽珠集团(000513.SZ)接受特定对象调研,摩根基金、工银理财等10家机构参与。公司就...
康芝药业:目前宏氏投资已给公司... 证券日报网讯 1月30日,康芝药业在互动平台回答投资者提问时表示,关于大股东回购中山爱护股权事宜,公...
小心,日本 来源:圆方你怎么看啊012026年2月8日,日本第51届国会众议院选举投票结束,日本广播协会(NHK...