java的Map集合 详解Map集合

Posted Jing<>

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java的Map集合 详解Map集合相关的知识,希望对你有一定的参考价值。

一、Map集合的特点

Map集合的特点
1.Map是一个双列集合,一个元素包含两个值(一个key,一个value)

2.Map集合中的元素,key和value的数据类型可以相同,也可以不同

3.Map中的元素,key不允许重复,value可以重复

4.Map里的key和value是一一对应的。

二、Map中的方法:

1.public   V  put (K key,V value) 把指定的键和值添加到Map集合中,返回值是V

如果要存储的键值对,key不重复返回值V是null

如果要存储的键值对,key重复返回值V是被替换的value值 

2. public  V remove(Object key)把指定键所对应的键值对元素,在Map集合中删除,返回被删除的元素的值。 返回值:V 。如果key存在,返回被删除的值,如果key不存在,返回null

 

3.public V remove (Object key):根据指定的键 在Map集合中获取对应的值

如果key存在,返回对应的value值,如果key不存在,返回null

 

  4.boolean containsKey( Object key)判判断集合中是否包含指定的键

包含返回true,不包含返回false

三、遍历Map集合的方式

1.通过键找值的方法;

使用了setKey方法,将Map集合中的key值,存储到Set集合,用迭代器或foreach循环遍历Set集合来获取Map集合的每一个key,并使用get(key)方法来获取value值

 

 2.使用Entry对象遍历

Map.Entry<K,V>,在Map接口中有一个内部接口Entry(内部类)

作用:当集合一创建,就会在Map集合中创建一个Entry对象,用来记录键与值(键值对对象,键值的映射关系)

 有了Entry对象就可以使用Map中的entrySet方法,把Map集合中的多个Entry对象存入一个Set集合来遍历Set集合,获取Set集合中每一个Entry对象,然后可以使用Entry中的两个方法getKey和getValue来分别获取键和值。

代码步骤:

 

 

 

四、Map的常用实现类

(一)、HashMap

【1】.特点:1.HashMap底是哈希表,查询速度非常快(jdk1.8之前是数组+单向链表,1.8之后是数组+单向链表/红黑树 ,链表长度超过8时,换成红黑树)

     2. HashMap是无序的集合,存储元素和取出元素的顺序有可能不一致

     3.集合是不同步的,也就是说是多线程的,速度快

【2】.HashMap存储自定义类型键值

HashMap存储自定义类型键值,Map集合保证key是唯一的:作为key的元素,必须重写hashCode方法和equals方法,以保证key唯一

 (二)LinkedHashMap

HashMap有子类LinkedHashMap:LinkedHashMap <K,V> extends HashMap <K,V>

是Map接口的哈希表和链表的实现,具有可预知的迭代顺序(有序)

底层原理:哈希表+链表(记录元素顺序)

特点:1.LinkedHashMap底层是哈希表+链表(保证迭代的顺序)

2.LinkedHashMap是一个有序的集合,存储元素和取出元素的顺序一致

改进之处就是:元素存储有序了

(三)Hashtable

Hashtable<K,V> implements Map<K,V>

Hashtable:底层也是哈希表,是同步的,是一个单线程结合,是线程安全的集合,速度慢

HashMap:底层也是哈希表,但是线程不安全的集合,是多线程集合,速度快

HashMap(还有之前学的所有集合):都可以存储null键,null值

Hashtable:不能存储null键,null值

Java集合-----Map详解

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

  •      Map 中的 key 和  value 都可以是任何引用类型的数据
  •      Map 中的 key 用Set来存放,不允许重复,即同一个,常用String类作为Map的“键”
  •      key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到唯一的、确定的 value

   1.HashMap

      HashMap是线程不安全的

package com.gather;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

public class HashMapPractise 
    public static void main(String[] args) 
        Map<String, Person> map = new HashMap<>();
        Person p1 = new Person("张三", 22);
        Person p2 = new Person("李四", 23);
        Person p3 = new Person("王五", 22);
        map.put("AA", p1);
        map.put("BB", p2);
        map.put("CC", p3);
        
        //第一种遍历方式:能同时取出键值对
        for(String str:map.keySet()) 
           System.out.println("键为:"+str+",值为:"+map.get(str));
        
        System.out.println("------------------------------");
        
        //第二种遍历方式:只取值或只取键
        for(String str:map.keySet()) 
            System.out.println("键为:"+str);
        
        
        for(Person person:map.values()) 
            System.out.println("值为:"+person);
        
        System.out.println("------------------------------");
        
        //推荐:第三种遍历方式:能同时取出键值对
        for(Entry<String,Person> entry:map.entrySet()) 
            System.out.println("键为:"+entry.getKey()+",值为:"+entry.getValue());
        
        System.out.println("------------------------------");
        
        //第四种遍历方式:能同时取出键值对
        Iterator<Entry<String, Person>> entries = map.entrySet().iterator(); 
        while (entries.hasNext())  
            Entry<String, Person> entry = entries.next(); 
            System.out.println("键为:"+entry.getKey()+",值为:"+entry.getValue()); 
        
    

   2.Hashtable

     Hashtable是线程安全的

package com.gather;

import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Map;
import java.util.Map.Entry;

public class HashtablePractise 
    public static void main(String[] args) 
        Map<String, Person> map = new Hashtable<>();
        Person p1 = new Person("张三", 22);
        Person p2 = new Person("李四", 23);
        map.put("AA", p1);
        map.put("BB", p2);

        for (Entry<String, Person> entry : map.entrySet()) 
            System.out.println("键为:" + entry.getKey() + ",值为:" + entry.getValue());
        
        System.out.println("------------------------------");

        Hashtable<String, Person> hashtable = new Hashtable<>();
        hashtable.put("AA", p1);
        hashtable.put("BB", p2);

        // Hashtable的另外一种遍历方式:Enumeration
        Enumeration<String> enuKey = hashtable.keys();
        while (enuKey.hasMoreElements()) 
            System.out.println(enuKey.nextElement());
        

        Enumeration<Person> enuValue = hashtable.elements();
        while (enuValue.hasMoreElements()) 
            System.out.println(enuValue.nextElement());
        
    

以上是关于java的Map集合 详解Map集合的主要内容,如果未能解决你的问题,请参考以下文章

Java集合-----Map详解

java集合Map集合之EnumMap详解

java如何对map进行排序详解(map集合的使用)

Java集合详解--什么是Map

Java集合详解--什么是Map

JAVA集合详解(Collection和Map接口)