双列集合map-1

1.了解map集合,map集合都有哪些实现?

  1.1 hashMap

  1.2 hashTable

  1.3 LinkedHashMap

  1.4 TreeMap

  1.5 ConcurrentHashMap

2.HashMap和HashTable之间的区别?

  2.1 HashMap:底层基于数组+链表(红黑树),非线程安全,允许有空的键和值;

  2.2 HashTable:底层基于哈希表实现的,线程安全,不允许有空的键和值;

  2.3 HashMap继承自AbstractMap类,,而HashTable是继承自Dictionary类;

  2.4 HashTable的初始容量为11,之后每次扩容,容量就变成了原来的2n+1;

  2.5 HashMap的初始容量为16,之后每次扩容,容量就变成了原来的2倍;

3.hashCode()和equals()方法使用场景?

  hashCode():顶级父类object当中的方法,返回值类型为int类型的值,根据一定的规则生成一个数组,数组保存的就是hash值;

  equals():顶级父类object当中的方法,根据一定的比较规则,判断对象是否一致;

    底层一般逻辑:

      1.判断两个对象的内存地址是否一样;

      2.非空判断和class类型判断;

      3.强转;

      4.对象中的字段一一匹配;

package com.wn.Test02;

import java.util.Objects;

public class Title {
    private int id;
    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public boolean equals(Object o) {
        //判断两个对象的内存地址是否一样
        if (this == o) return true;
        //非空判断和class类型判断
        if (o == null || getClass() != o.getClass()) return false;
        //强转
        Title title = (Title) o;
        //对象中的字段一一匹配
        return id == title.id &&
                Objects.equals(name, title.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(id, name);
    }
}

4.HashMap和TreeMap安排应该如何选择?

  HashMap:底层采用数组+链表结构,可以实现快速的存储和检索,但是数据时无序的,适用于在map当中插入删除或者获取元素;

  TreeMap:存储结构是一个平衡二叉树,具体实现方式为红黑树,默认采用自然排序,可以自定义排序规则,但是需要实现Comparator,能够便捷的实现内部元素的各种排序,但是性能比HashMa差,适用于按照具体自然排序和自定义排序规则;

5.Map和Set的关系?

  Map是一组键值对的结构,具有极快的查找速度;

  Set核心就是保存不重复的元素,存储一组唯一的对象;

  Set当中每一种实现都对应Map;

  HashSet对应的底层就是new HashMap,TreeSet对应的底层就是new TreeMap;

    

    

6.常见的Map排序规则?

  6.1 TreeMap排序  

    TreeMap只能根据key进行排序,TreeMap本身是个二叉树,元素的顺序是由key的值决定的;

    按照自然排序可以采用TreeMap;

package com.wn.Test02;

import java.util.Map;

public class TreeMap {
    public static void main( String[] args ){
        java.util.TreeMap<String, String> map = new java.util.TreeMap<String,String>();
        map.put("1","A");
        map.put("2","B");
        map.put("3","C");
        map.put("4","D");
        map.put("5","E");
        System.out.println(map);
    }
}

    

  6.2 HashMap排序

    HashMap本身是没有顺序的,不能直接对其进行排序;

    要排序,只能先转成list;

package com.wn.Test02;

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

public class HashMapTest {
    public static void main( String[] args ){
        HashMap<Integer,String> map = new HashMap<Integer,String>();
        map.put(1,"A");
        map.put(3,"B");
        map.put(2,"C");
        map.put(4,"D");
        map.put(5,"E");
        ArrayList<Object> list = new ArrayList<>();
        for (Map.Entry<Integer,String> entry:map.entrySet()){
            System.out.println("entry.getKey.hash:"+entry.getKey().hashCode());
            list.add(entry.getValue());
        }
        System.out.println(list);
    }

}

    

  6.3 LinkedHashMap排序

    插入顺序,遍历LinkedHashMap时,先得到的记录肯定是先插入的;

package com.wn.Test02;

import java.util.*;

public class LinkedListTest {
    public static void main( String[] args ){
        LinkedHashMap<String, String> map = new LinkedHashMap<>();
        for (int i=0;i<10;i++){
            map.put("key"+i,"value"+i);
        }
        map.get("key"+3);
        for (String value:map.keySet()){
            System.out.println(value);
        }

    }
}

    

    添加规则是可以使用LinkedHashMap;

7.如何让map线程安全?

  7.1 多线程环境下,可以使用concurrent包下有一个ConcurrentHashMap,它使用分段锁来保证线程安全;

  7.2 Collections.synchronizedMap保证线程安全,效率比HashTable高;

    

原文地址:https://www.cnblogs.com/wnwn/p/12503600.html

时间: 2024-10-03 23:20:22

双列集合map-1的相关文章

java018.双列集合Map

day18双列集合MapMap接口和Collection接口的区别: * Map是双列的,Collection是单列的 * Map的键唯一,Collection的子体系Set是唯一的,List体系可以存储重复值 * Map集合的数据结构值针对键有效,跟值无关;Collection集合的数据结构是针对元素有效 * a:添加功能  * V put(K key,V value):添加元素.   * 如果键是第一次存储,就直接存储元素,返回null   * 如果键不是第一次存在,就用值把以前的值替换掉,

双列集合Map及实现该接口的类的常用方法

为什么要学双列集合? 因为单列集合无法处理映射关系,会有成对出现的数据 Map接口  如果是实现了Map接口的集合类,具备的特点: 存储的数据都是以键值对的形式存在的,键不可重复,值可以重复 Map接口的方法:   添加:    put(K key, V value)     putAll(Map<? extends K,? extends V> m)    删除    remove(Object key)     clear()   获取:    get(Object key)     si

集合面试题之双列集合Map

一.了解Map集合吗?Map集合都有哪些实现 HashMap .HashTable.    LinkedHashMap .TreeMap.   ConcurrentHashMap HashMap底层数据结构是哈希表,所以其特点是元素无序且唯一(自定义对象需要重写hashCode和equals方法保证他的唯一性) Hashtable它和HashMap类很相似,但是它支持同步,Hashtable在哈希表中存储键/值对,当使用一个哈希表,要指定用作键的对象,以及要链接到该键的值. 然后,该键经过哈希处

Map集合(双列集合)

Map集合(双列集合)Map集合是键值对集合. 它的元素是由两个值组成的,元素的格式是:key=value. Map集合形式:{key1=value1 , key2=value2 , key3=value3 , .. } * Map集合系列: Map<K,V>(接口) / HashMap<K,V>(实现类) / LinkedHashMap<K,V>注意:Map集合只支持引用数据类型的元素存储. Map集合特点: 键是无序不重复的. 重复的键,后面加入的会直接覆盖前面.

双列集合框架:Map(个人理解)

双列集合框架:Map1.常用实现类结构|----Map:双列数据,存储key-value对的数据 ---类似于高中的函数:y = f(x)* |----HashMap:作为Map的主要实现类:线程不安全的,效率高:存储null的key和value* |----LinkedHashMap:保证在遍历map元素时,可以照添加的顺序实现遍历.* 原因:在原的HashMap底层结构基础上,添加了一对指针,指向前一个和后一个元素.* 对于频繁的遍历操作,此类执行效率高于HashMap.* |----Tre

JAVA双列集合HashMap

HashMap 双列集合HashMap是属于java集合框架3大类接口的Map类,   Map接口储存一组成对的键-值对象,提供key(键)到value(值)的映射.Map中的key不要求有序,不允许重复.value同样不要求有序,但允许重复. Iterator接口是负责定义访问和遍历元素的接口 1. 使用Iterator迭代器缺点: 1. ListIterator有add()方法,可以向List中添加对象,而Iterator不能 2. ListIterator和Iterator都有hasNex

集合(三)------双列集合

所谓双列集合就是存在映射关系并且是成对存在的. 双列集合体系: -------------| Map  如果是实现了Map接口的集合类,具备的特点: 存储的数据都是以键值对的形式存在的,键不可重复,值可以重复.----------------| HashMap  底层也是基于哈希表实现 的.----------------| TreeMap   TreeMap也是基于红黑树(二叉树)数据结构实现 的, 特点:会对元素的键进行排序存储.----------------| Hashtable 和ha

获取单列集合,双列集合,数组的Stream流对象以及简单操作

获取流对象 获取单列集合,双列集合,数组的流对象 单列集合获取流对象: 1.java.util.Collection接口中加入了default方法stream()获取流对象,因此其所有实现类均可通过此方式获取流. public class StreamTest01 { List<String> list = new ArrayList<>(); Stream<String> stream1 = list.stream(); Set<String> set =

java基础35 双例集合Map及其常用方法

单例集合的体系: ---------| collection  单例集合的根接口--------------| List  如果实现了list接口的集合类,具备的特点:有序,可重复       注:集合中的有序不是指自然顺序,而是指添加进去的顺序与出来的顺序是一致的------------------| ArrayList  ArrayList底层维护了一个object数组的实现的.(线程不安全),特点:查询速度快,增删速度慢.(有序,可重复)------------------| Linked

Collection单列集合 Map双列集合

Map集合:该集合存储键值对,一对一对往里存.而且要保证键的唯一性. 1.添加 put(K key, V value) putAll(Map<? extends K,? extends V> m) 2.删除 clear() remove(Object key) 3.判断 containsKey(Object key) containsValue(Object value) isEmpty() 4.获取 get(Object key) :获取值 size() values() entrySet(