iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >详解Java集合类之Map篇
  • 852
分享到

详解Java集合类之Map篇

2024-04-02 19:04:59 852人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录1.Map接口介绍2.Map接口分析3.Map接口方法4.Map遍历方式1.Map接口介绍 Map用于保存具有映射关系的数据:Key - Value 对于Set,底层其实依然是一

1.Map接口介绍

Map用于保存具有映射关系的数据:Key - Value

对于Set,底层其实依然是一个Map,但是Set选择不使用Value,也就是Set的Value值始终是一个常量

Map中的Key和Value可以是任何类型的数据,会封装到HashMap$node对象中

Map中的Key不能重复,但是Value可以重复,当有相同的Key时,等价与替换操作

2.Map接口分析

存放Map键值对是在HashMap$Node中

tab[i] = newNode(hash, key, value, null);

--

Node<K,V> newNode(int hash, K key, V value, Node<K,V> next) {
    return new Node<>(hash, key, value, next);
}

那么这个Node节点的数据类型是什么样的呢?

我们来看一下源代码:(其还实现了Entry接口)

static class Node<K,V> implements Map.Entry<K,V> {
    final int hash;  // 存放hash值
    final K key;  // 存放key值
    V value;  // 存放Value值
    Node<K,V> next;  // 存放下一个个节点,以形成链表结构
}

k-v为了方便程序员的遍历,还会创建一个EntrySet集合,该集合存放的元素类型是Entry,而一个Entry对象含有k,v,但是本质上这里的k-v值还是指向一个Node节点中的数据,也就是这里的k-v存放的依然是地址数据

// k-v存在有EntrySet的一个指向
Set set = map.entrySet();
System.out.println(set.getClass());

输出:

class java.util.HashMap$EntrySet

那么,这个方便程序员遍历的特性是如何体现的呢?

原因是Map.Entry提供了两个非常重要的方法:K geTKEy(); V getValue();。所以我们可以通过如下的方式进行遍历Map:

Set set = map.entrySet();
System.out.println(set.getClass());
for (Object obj : set) {
    Map.Entry entry = (Map.Entry) obj;
    System.out.println(entry.getKey());
    System.out.println(entry.getValue());
}

那怎么证明Entry里面存放的k-v只是地址的指向呢?很简单

通过debug,我们先来看一下Map中存放的数据,其no2这个键的地址是@727

再来看一下set中no2键的地址,一模一样:

3.Map接口方法

代码示例:

Map map = new HashMap();
// 添加键值对
map.put("no1","dahe");
map.put("no2","zhangsan");
// Key重复会进行替换
map.put("no1","lisi");
System.out.println(map);

// 根据键删除映射关系
map.remove("no1");
System.out.println(map);
// 根据key得到值
Object no2 = map.get("no2");
System.out.println(no2);
// 获取键值对数量
System.out.println(map.size());
// 判空
System.out.println(map.isEmpty());
// 清空
// map.clear();
// 查找键是否存在
System.out.println(map.containsKey("ok"));

4.Map遍历方式

第一式:取出所有的key,通过key取出对应的value

// 取出所有的key,通过key取出对应的value
Set keySet = map.keySet();
for (Object o : keySet) {
    System.out.println(o);
    System.out.println(map.get(o));
}

第二式:把所有的value值取出

// 把所有的value值取出
Collection values = map.values();
for (Object value : values) {
    System.out.println(value);
}

第三式:通过EntrySet来获取 k-v

// 通过EntrySet来获取 k-v
Set entrySet1 = map.entrySet();
for (Object o : entrySet1) {
    // 将entry 转成 Map.Entry
    Map.Entry m = (Map.Entry) o;
    System.out.println(m.getKey());
    System.out.println(m.getValue());
}

到此这篇关于详解Java集合类之Map篇的文章就介绍到这了,更多相关Java集合类Map内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详解Java集合类之Map篇

本文链接: https://www.lsjlt.com/news/165304.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作