06_1_Map 接口中的常用方法

package com.itheima.demo01.Map;

import java.util.HashMap;
import java.util.Map;

/*
    java.util.Map<K,V>
    Map集合得特点:
        1.Map集合是一个双列集合,一个元素包含两个值
        2.Map集合中的元素,key和value的数据类型可以相同,也可以不同
        3.Map集合中的元素,key是不允许重复的,value是可以重复的
        4.Map集合中的元素,key和value是一一对应的
    java.util.HashMap集合  implements Map
    HashMap集合的特点:
        1.HashMap集合底层是哈希表,查询速度快
            JDK1.8之前:数组+单向链表
            JDK1.8之后:数组+单向链表/红黑树(链表长度超过8)
        2.HashMap集合是一个无序的集合,存储元素和取出元素的顺序不一致
    java.util.LinkedHashMap extends HashMap
    LinkedHashMap的特点:
        1.LinkedHashMap集合底层是哈希表+链表(保证迭代顺序)
        2.LinkedHashMap集合是一个有序的集合,存储元素和去除元素的顺序是一致的
 */
public class Demo01Map {
    public static void main(String[] args) {
        show04();
    }

    /*
        boolean containsKey(Object key) 判断集合中是否包含指定的键。
     */
    private static void show04() {
    }

    /*
        public V get(Object key) 根据指定的键,在Map集合中获取对应的值。
            返回值:
                key存在返回对应的值
                key不存在,返回null
     */
    private static void show03() {
        Map<String, Integer> map = new HashMap<>();
        map.put("licheng", 123);
        map.put("lenggeng", 111);
        map.put("yangguo", 12);
        map.put("yinzhiping", 33);
        Integer v1 = map.get("licheng");//123
        Integer v2 = map.get("fadsfasd");//null

    }

    /*
        public V remove(Object key): 把指定的键 所对应的键值对元素 在Map集合中删除,返回被删除元素的值
            返回值v:
                key存在,v返回被删除的值
                key不存在,返回null
     */
    private static void show02() {
        Map<String, Integer> map = new HashMap<>();
        map.put("licheng", 123);
        map.put("lenggeng", 111);
        map.put("yangguo", 12);
        map.put("yinzhiping", 33);
        Integer v1 = map.remove("yinzhiping");//33
        System.out.println(map);//{yangguo=xiaolongnv, lenggeng=longxiaoyun, licheng=fanbingbing}
//        int v2 = map.remove("fdsfsda");//自动拆箱  NullPointerException空指针异常   null不能赋值给int
        Integer v2 = map.remove("fdasfdsa");//null

    }

    /*
        public V put(K key, V value): 把指定的键与指定的值添加到Map集合中。
            返回值:V
                存储键值对的时候,key不重复,返回值是null
                存储键值对的时候,key重复,会使用新的value替换map中重复的value,返回被替换的value值
     */
    private static void show01() {
        //创建Map集合,多态
        Map<String, String> map = new HashMap<>();
        String v1 = map.put("licheng", "fanbingbing");//null
        String v2 = map.put("licheng", "fanbingbing");//fanbingbing
        System.out.println(map);//{licheng=fanbingbing}
        map.put("lenggeng", "longxiaoyun");
        map.put("yangguo", "xiaolongnv");
        map.put("yinzhiping", "xiaolongnv");
        System.out.println(map);
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值