java 中Map详解及实例代码
发布时间 - 2026-01-11 00:34:43 点击率:次Map接口

Map类似y(x)=x;这样的函数(key对应x,value对应y)
Map与Collection并列存在。用于保存具有映射关系的数据:Key-Value
Map 中的 key 和 value 都可以是任何引用类型的数据
Map 中的 key 用Set来存放,不允许重复,即同一个 Map 对象所对应的类,须重写hashCode()和equals()方法。
常用String类作为Map的“键”。
key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到唯一的、确定的 value。
Map接口
丨---------HashMap:Map的主要实现类 丨---------TreeMap:按照添加进Map中的元素的key的指定属性进行排序,要求:key必须是同一个类的对象!针对key:自然排序 vs 定制排序 丨---------Hashtable:是一个古老的实现类,线程安全,与HashMap不同,它不允许使用null作为key和value(不建议使用)(有多老!看命名就知道,连驼峰命名法都木有用上!哈哈哈哈哈!) 丨---------Properties:常用来处理属性文件。键和值都为String类型的。(这儿你常用的配置文件就是)
public class TestMap{
/*
*
*Object put(Object key,Object value):向Map中添加一个元素
*
*Object remove(Object key):按照指定的key删除此key-value对
*
*void putAll(Map t):
*
*void clear():清空
*
*Object get(Object key):获取指定key的value值,若无此key则返回null
*
*boolean containsKey(Object key):
*
*boolean containsValue(Object value)
*
*int size()
*
*boolean isEmpty()
*
*boolean equals(Object obj)
*
*HashMap:
*1.key是用Set来存放的,不可重复,value是用Collection来存放的,可重复
* 一个key-value对,是一个Entry,所有的Entry是用Set存放的,也是不可重复的。
*2.向HashMap中添加元素时,会调用key所在类的equals()方法,判断两个key是否相同,若相同则只能够添加进一个,则只能添加进后加的那个元素
*
*/
//两个put的key相同,输出结果为后加进去的那个,所以输出是value=87
public void test1(){
Map map = new HashMap();
map.put("AA",213);
map.put("BB",456);
map.put("BB",45);//与上边的key相同所以map中是这个
map.put(123,"CC");
map.put(null,null);
map.put(new Person("xx",21),89);
map.put(new Person("xx",21),87);//与上边的key相同所以map中是这个
System.out.println(map.size());
map.remove("BB");
System.out.println(map);
Object value = map.get(123);
System.out.println(value);
}
/*
如何遍历Map
Set keySet()
Collection values()
Set entrySet()
*/
@Test
public void test2(){
Map map = new HashMap();
map.put("AA",213);
map.put("BB",45);
map.put(123,"CC");
map.put(null,null);
map.put(new Person("xx",21),89);
//1.遍历key集.此时打印输出 null,AA,Person //[name=DD,age=23],BB,123
Set set = map.keySet();
for(Object obj : set){
System.out.println(obj);
}
//2.遍历value集.此时打印输出null,213,89,45,CC
Collection values = map.values();
Iterator i = values.iterator();
while(i.hasNext()){
System.out.println(i.next());
}
//3.如何遍历key-value对
//方式一
Set set1 = map.keySet();
for(Object obj1 : set1){
System.out.println(obj + "----->" + map.get(obj));
}
//方式二
Set set2 = map.entrySet();
for(Object obj : set2 ){
Map.Entry entry = (Map.Entry)obj;
System.out.println(entry.getKey() + "---->" + entry.getValue());
}
}
@Test
public void testLinkedHashMap(){
Map map = new LinkedHashMap();
map.put("AA",213);
map.put("BB",45);
map.put(123,"CC");
map.put(null,null);
map.put(new Person("xx",21),89);
Set set1 = map.keySet();
for(Object obj1 : set1){
System.out.println(obj + "----->" + map.get(obj));
}
}
@Test
public void testTreeMap(){
//自然排序
Map map = new TreeMap();
map.put(new Person("AA",23),89);
map.put(new Person("MM",22),79);
map.put(new Person("BB",23),99);
map.put(new Person("CC",13),69);
Set set1 = map.keySet();
for(Object obj1 : set1){
System.out.println(obj + "----->" + map.get(obj));
}
}
@Test
public void testProperties(){
Properties pros = new Properties();
pros.load(new FileInputStream(new File(jdbc.properties )));
String user = pros.getProperty("user");
String password = pros.getProperty("password");
}
}
<下面重点:>
/* 操作Collection以及Map的工具类:Collections 面试题:区分Collection和Collections reverse(List):反转List中元素的位置 shuffle(List):对List集合元素进行随机排序 sort(List): sort(List,Comparator): swap(List,int,int): */ List list = new ArrayList(); list.add(123); list.add(23); list.add(33); list.add(43); list.add(53); List list2 = new ArraysList();//若用list2当src来复制list集合则会报错,出现数组越界,以为新定义的集合长度是0,而源集合长度是5,塞不进去 List list1 = Arrays.asList(new Object[list.size()]);//将数组作为list长度直接取 Collections.copy(list1,list);//调用工具类不用返回值 -----------------同步控制 synchronized()方法 //通过如下的方法保证list的线程安全性。安全性高了但是效率低啊! List list2 = Collections.synchronizedList(list); System.out.println(list2);
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# java
# Map
# Map详解
# Map简单实例
# Java中HashMap和TreeMap的区别深入理解
# Java中List与Map初始化的一些写法分享
# JAVA HashMap详细介绍和示例
# java如何对map进行排序详解(map集合的使用)
# Java集合Set、List、Map的遍历方法
# java中关于Map的三种遍历方法详解
# Java Map的几种循环方式总结
# java中数组list map三者之间的互转介绍
# java集合map取key使用示例 java遍历map
# 遍历
# 是一个
# 后加
# 有多
# 希望能
# 重写
# 报错
# 谢谢大家
# 它不
# 高了
# 都为
# 则会
# 若无
# 配置文件
# 清空
# 不进去
# 返回值
# 所对应
# 面试题
# 就知道
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
简单实现jsp分页
详解CentOS6.5 安装 MySQL5.1.71的方法
php结合redis实现高并发下的抢购、秒杀功能的实例
Python制作简易注册登录系统
微信小程序 canvas开发实例及注意事项
JS去除重复并统计数量的实现方法
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何快速上传自定义模板至建站之星?
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
晋江文学城电脑版官网 晋江文学城网页版直接进入
如何快速搭建高效可靠的建站解决方案?
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
如何彻底卸载建站之星软件?
韩国服务器如何优化跨境访问实现高效连接?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
Java垃圾回收器的方法和原理总结
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
EditPlus中的正则表达式 实战(2)
在线制作视频的网站有哪些,电脑如何制作视频短片?
PythonWeb开发入门教程_Flask快速构建Web应用
微信小程序 HTTPS报错整理常见问题及解决方案
php json中文编码为null的解决办法
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
网站优化排名时,需要考虑哪些问题呢?
如何快速使用云服务器搭建个人网站?
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析
JavaScript数据类型有哪些_如何准确判断一个变量的类型
浅谈redis在项目中的应用
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
EditPlus 正则表达式 实战(3)
nginx修改上传文件大小限制的方法
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
MySQL查询结果复制到新表的方法(更新、插入)
Laravel如何升级到最新版本?(升级指南和步骤)
JS经典正则表达式笔试题汇总
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
如何快速查询网站的真实建站时间?
七夕网站制作视频,七夕大促活动怎么报名?
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
如何在万网ECS上快速搭建专属网站?

