当前位置: 首页 > news >正文

Map接口及遍历方式

1、Map接口实现类的特点

1)Map与Collection并列存在。用于保存具有映射关系的数据:Key-Value(无序)

2) Map中的key和value可以是任何引用类型的数据,会封装到HashMap$Node对象中

3) Map 中的key不允许重复

import java.util.HashMap;
import java.util.Map;public class Map_ {public static void main(String[] args) {Map map = new HashMap();map.put("no1","张三");map.put("no2","李四");
//        key相同相当于替换map.put("no1","张桑");System.out.println(map);}
}
将no1的张三换成张桑

运行结果:

4)Map中的value可以重复

import java.util.HashMap;
import java.util.Map;public class Map_ {public static void main(String[] args) {Map map = new HashMap();map.put("no1","张三");map.put("no2","李四");
//        key相同相当于替换map.put("no1","张四");map.put("no3","李四");System.out.println(map);}
}

运行结果:

5) Map 的key可以为null, value也可以为null,注意key为null,只能有一个,value为null ,可以多个

·import java.util.HashMap;
import java.util.Map;public class Map_ {public static void main(String[] args) {Map map = new HashMap();map.put("no1","张三");map.put("no2","李四");
//        key相同相当于替换map.put("no1","张四");map.put("no3","李四");map.put(null,null);map.put("no4",null);map.put(null,“王五”);会替换System.out.println(map);}
}

6)常用字符串类作为Map的key

import java.util.HashMap;
import java.util.Map;public class Map_ {public static void main(String[] args) {Map map = new HashMap();map.put("no1","张三");map.put("no2","李四");
//        key相同相当于替换map.put("no1","张四");map.put("no3","李四");map.put(null,null);map.put("no4",null);map.put(null,"王五");
//        String类型可以作为Map的keymap.put(3,"美女");map.put(new Object(),"金毛狮王");System.out.println(map);}
}

运行结果:

7) key 和 value之间存在单向一对一关系,即通过指定的key总能找到对应的value

import java.util.HashMap;
import java.util.Map;public class Map_ {public static void main(String[] args) {Map map = new HashMap();map.put("no1","张三");map.put("no2","李四");
//        key相同相当于替换map.put("no1","张四");map.put("no3","李四");//        通过get方法,通过key可以找到对应的值System.out.println(map);System.out.println(map.get("no1"));}
}

运行结果:

2.Map遍历的几种方式

2.1 第一组先取出所有的key,通过key 取出对应的Value

import java.util.*;public class Map3 {public static void main(String[] args) {
//        map接口常用方法Map map = new HashMap();
//        map.put("邓超",new Book1("",100));map.put("邓超","孙俪");map.put("王宝强","马蓉");map.put("宋喆","马蓉");map.put("刘凌波",null);map.put(null,"刘亦菲");map.put("鹿晗","关晓彤");
//        第一组先取出所有的key,通过key 取出对应的ValueSet keySet= map.keySet();System.out.println("第一种方式");for (Object key:keySet) {System.out.println(key+"-"+map.get(key));}
//      迭代器快捷键ititSystem.out.println("迭代器*********");Iterator iterator = keySet.iterator();while (iterator.hasNext()) {Object key =  iterator.next();System.out.println(key+"-"+map.get(key));}
}

2.2直接取出值

 Collection values =map.values();System.out.println("取出所有的值");for (Object value:values) {System.out.println(value);}
//  迭代器System.out.println("迭代器");Iterator iterator2 = values.iterator();while (iterator2.hasNext()) {Object value=  iterator2.next();System.out.println(value);}

2.3通过EntrySet来获取k-v

   Set entrySet= map.entrySet();System.out.println("  通过EntrySet来获取k-v");for (Object entry :entrySet) {
//            将entry转成map.EntryMap.Entry m = (Map.Entry) entry;System.out.println(map.get(m.getKey())+"-"+m.getValue());}
//        迭代器System.out.println("迭代器**********");Iterator iterator3 =entrySet.iterator();while (iterator3.hasNext()) {Object entry =  iterator3.next();
//            向下转型Map.Entry n=(Map.Entry) entry;System.out.println(n.getKey() + "-"+n.getValue());}
http://www.lryc.cn/news/39167.html

相关文章:

  • 一步步构建自己的前端项目
  • VMware搭建Mac OS环境
  • 【Maven】什么是Maven?Maven有什么用?
  • 【JavaSE】类和对象的详解
  • 2023年中职组“网络安全”赛项广西自治区竞赛任务书
  • 简单的自定义录屏工具
  • 数据结构与算法基础(王卓)(17):KMP算法详解(精讲(最简单、直接、有效的思路方法,答案以及代码原理)
  • 【java基础】HashMap源码解析
  • 实现异步的8种方式,你知道几个?
  • 二叉树的三种遍历
  • 我,30岁程序员被裁了,千万别干全栈
  • 【linux】:进程地址空间
  • 【保姆级】JMeter Mqtt 压测配置
  • C语言数据结构初阶(4)----带头双向循环链表
  • 原生javascript手写一个丝滑的轮播图
  • 【Linux】进程优先级(进程优先级 Linux下优先级 用top命令更改已存在进程的nice 其他概念 进程切换)
  • 2016年chatGPT之父Altman与马斯克的深度对话(值得一看)
  • 基于vscode开发vue3项目的详细步骤教程 3 前端路由vue-router
  • 【C语言】每日刷题 —— 牛客语法篇(5)
  • 操作系统(2.1)--进程的描述与控制
  • JAVA查看动态代理类
  • Chapter2 : SpringBoot配置
  • 手撕单链表练习
  • Kubuntu安装教程
  • [蓝桥杯] 树状数组与线段树问题(C/C++)
  • Matlab-Loma Prieta 地震分析
  • Spring Boot全局异常处理
  • websocket每隔5秒给服务端send一次信息
  • 2023年中职网络安全——SQL注入测试(PL)解析
  • 利用蜜罐捕捉攻击实验(31)