Java Map集合详解与演示

网友投稿 213 2022-09-13


Java Map集合详解与演示

目录一、前言二、Map介绍三、Map的基本功能Map功能演示:四、 Map集合的获取功能Map遍历演示:

一、前言

map集合是我们常使用的集合,了解和使用map集合是必要的

二、Map介绍

基本形式: public interface Map

Map是一个接口,我们不能直接创建对象,可以通过多态的形式创建对象,Map中有两个

参数,一个是K表示键,一个是V表示值,且一个键有且对应一个值,Map中不能包含重复的

键,若是有重复的键添加,则会以最后一次的键为准,而其他的键会被覆盖。集合都在

java.util包下,所以需要导包。

具体实现常用的一般有两种,一是HashMap,另一个是TreeMap

import java.util.HashMap;

import java.util.Map;

public class MapTest {

public static void main(String[] args) {

Map map=new HashMap<>();

map.put("2001", "张三");

map.put("2002", "张三");

map.put("2003", "李四");

map.put("2003", "王五");//键重复,会覆盖上一个,留下最新的

System.out.println(map);//{2003=王五, 2002=张三, 2001=张三}

}

}

由上可知,map中的键是不能重复的,而值是可以重复的可以直接通过输出对象来得到

集合的内容,说明此集合内重写了toString方法。

三、Map的基本功能

这些功能是常见的,掌握这些即可

Map功能演示:

import java.util.HashMap;

import java.util.Map;

public class MapTest {

public static void main(String[] args) {

//创建Map集合对象

Map map=new HashMap<>();

//增加元素

map.put("2001", "张三");

map.put("2002", "李四");

map.put("2003", "王五");

System.out.println(map);//{2003=王五, 2002=李四, 2001=张三}

//根据键删除元素

// map.remove("2001");

//System.out.println(map);//{2003=王五, 2002=李四}

//判断集合中是否包含指定的键返回boolean类型

System.out.println(map.containsKey("2001"));//true

System.out.println(map.containsKey("2004"));//false

//判断集合中是否包含指定的值返回boolean类型

System.out.println(map.containsValue("张三"));//true

yOlabnMryU System.out.println(map.containsValue("赵六"));//false

//判断集合是否为空返回boolean类型

System.out.println(map.isEmpty());//false

//得到集合的长度

System.out.println(map.size());//3

//清除所有键值对

map.clear();

System.out.println(map.isEmpty());//true,为空了

}

}

四、 Map集合的获取功能

此方法多是用在遍历集合时,前三种比较常用也比较好记。

Map遍历演示:

import java.util.HashMap;

import java.util.Map;

import java.util.Set;

public class Maptest2 {

public static void main(String[] args) {

Map map = new HashMap<>();

map.put("2001", "张三");

map.put("2002", "李四");

map.put("2003", "王五");

//遍历集合

//方式1:

// 由键找值,创建键的集合

Set keySet=map.keySet();

//遍历键的集合,得到每一个键

for (String key:keySet){

//由键找值

String value=map.get(key);

//输出键和值

System.out.print(key+" "+value+", ");

}

System.out.println("\n------------");

//方式2:

//获取所有键值对的集合

Set> entrySet =map.entrySet();

//遍历键值对集合

for (Map.Entry me:entrySet){

//分别得到键和值

yOlabnMryU String key=me.getKey();

String value=me.getValue();

System.out.print(key+" "+value+", ");

}

}

}

如图:


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:cisco数据中心理论小记-1(cisco第一章考试答案)
下一篇:cisco ASA 551X系列防火墙限速(cisco是什么公司)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~