news 2026/4/23 22:45:10

java基础-Map接口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java基础-Map接口

在Java中,Map是一个非常重要的接口,它表示键值对(Key-Value)的映射集合。Map 不允许重复的键,每个键最多只能映射到一个值。

Map 接口的主要特点

  • 键唯一性:不允许重复的键

  • 键值对存储:每个元素包含一个键和一个值

  • 无序(某些实现类有序):不保证元素的顺序

常用的 Map 实现类

1. HashMap

import java.util.*; // 创建 HashMap Map<String, Integer> hashMap = new HashMap<>(); // 添加元素 hashMap.put("Alice", 25); hashMap.put("Bob", 30); hashMap.put("Charlie", 28); // 获取元素 int age = hashMap.get("Alice"); // 25 // 遍历 Map for (Map.Entry<String, Integer> entry : hashMap.entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue()); }

2. LinkedHashMap

// 保持插入顺序 Map<String, Integer> linkedHashMap = new LinkedHashMap<>(); linkedHashMap.put("Zoe", 22); linkedHashMap.put("Alice", 25); linkedHashMap.put("Bob", 30); // 遍历时保持插入顺序 for (String key : linkedHashMap.keySet()) { System.out.println(key); // Zoe, Alice, Bob }

3. TreeMap

// 按键的自然顺序或自定义比较器排序 Map<String, Integer> treeMap = new TreeMap<>(); treeMap.put("Zoe", 22); treeMap.put("Alice", 25); treeMap.put("Bob", 30); // 遍历时按键排序 for (String key : treeMap.keySet()) { System.out.println(key); // Alice, Bob, Zoe }

常用方法

Map<String, String> map = new HashMap<>(); // 添加元素 map.put("key1", "value1"); map.put("key2", "value2"); // 获取元素 String value = map.get("key1"); // 检查键是否存在 boolean exists = map.containsKey("key1"); // 检查值是否存在 boolean valueExists = map.containsValue("value1"); // 删除元素 map.remove("key1"); // 获取大小 int size = map.size(); // 检查是否为空 boolean isEmpty = map.isEmpty(); // 获取所有键的集合 Set<String> keys = map.keySet(); // 获取所有值的集合 Collection<String> values = map.values(); // 获取所有键值对的集合 Set<Map.Entry<String, String>> entries = map.entrySet(); // 清空Map map.clear();

Java 8+ 的新特性

Map<String, Integer> map = new HashMap<>(); // putIfAbsent - 如果键不存在则添加 map.putIfAbsent("key1", 100); // compute - 计算新值 map.compute("key1", (k, v) -> v == null ? 0 : v + 1); // computeIfAbsent - 如果键不存在则计算新值 map.computeIfAbsent("key2", k -> 50); // computeIfPresent - 如果键存在则计算新值 map.computeIfPresent("key1", (k, v) -> v * 2); // merge - 合并值 map.merge("key1", 10, (oldValue, newValue) -> oldValue + newValue); // forEach - 遍历 map.forEach((k, v) -> System.out.println(k + ": " + v)); // getOrDefault - 获取值或默认值 int value = map.getOrDefault("nonexistent", 0);

线程安全的 Map

ConcurrentHashMap

import java.util.concurrent.ConcurrentHashMap; // 线程安全的 HashMap Map<String, Integer> concurrentMap = new ConcurrentHashMap<>(); concurrentMap.put("key1", 100);

Collections.synchronizedMap

// 将普通 Map 转换为线程安全的 Map Map<String, Integer> syncMap = Collections.synchronizedMap(new HashMap<>());

使用示例

public class MapExample { public static void main(String[] args) { // 统计单词出现次数 String text = "hello world hello java world java programming"; String[] words = text.split(" "); Map<String, Integer> wordCount = new HashMap<>(); for (String word : words) { wordCount.merge(word, 1, Integer::sum); } // 输出结果 wordCount.forEach((word, count) -> System.out.println(word + ": " + count)); } }

Map 是 Java 集合框架中非常实用的数据结构,广泛应用于缓存、配置管理、数据统计等场景。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:49:50

string,byte,rune,character?详解Golang编码-UTF-8

理解 Go 语言中的字符串、字节与符文 &#x1f4d6; 引言 我们之前的博文详细解释了 Go 语言切片的工作原理&#xff0c;并辅以大量示例阐明了其实现机制。在此背景下&#xff0c;本文将深入探讨 Go 语言中的字符串。乍一看&#xff0c;字符串似乎是一个过于简单的话题&#…

作者头像 李华
网站建设 2026/4/23 13:44:21

基于改进粒子群优化支持向量机(IPSO - SVM)的数据回归预测

基于改进粒子群优化支持向量机(IPSO-SVM)的数据回归预测 IPSO-SVM回归 改进点&#xff1a;线性权重递减 采用 Libsvm 工具箱&#xff08;无需安装&#xff0c;可直接运行&#xff09;&#xff0c;仅支持 Windows 64位系统 此处为回归&#xff0c;需要分类和时序预测也可以。 需…

作者头像 李华
网站建设 2026/4/23 13:39:01

训练速度飙升5倍!Unsloth动态量化让大模型微调告别“卡脖子”

还在为大模型微调的速度慢、显存爆而烦恼&#xff1f;Unsloth的黑科技让你在消费级GPU上也能轻松玩转百亿参数模型&#xff01; 摘要 Unsloth 是一个革命性的大型语言模型&#xff08;LLM&#xff09;高效微调框架。它通过独家手动推导并编写的GPU内核&#xff0c;在不改变硬件…

作者头像 李华
网站建设 2026/4/23 12:58:48

Nmap深度解析:信息收集

概述 (Overview) Nmap (“Network Mapper”) 是一款开源且功能强大的网络扫描工具&#xff0c;广泛用于网络发现和安全审计。它利用原始 IP 报文来发现网络上的主机、探测这些主机开放的端口、确定端口上运行的服务及其版本、推测目标操作系统&#xff0c;并可通过 Nmap 脚本引…

作者头像 李华