美文网首页
集合 -- Map映射

集合 -- Map映射

作者: 咔狼 | 来源:发表于2018-10-20 13:44 被阅读0次

Map映射

  • Map集合的数据结构仅仅针对键有效,和值无关
  • 存储的是键值对元素,键是唯一的,值可重复
HashMap
  • 底层数据结构由哈希表实现,它不保证set的迭代顺序
  • 依赖hashCode()equals()方法来区分存入的元素是否相同,来保证存储元素唯一性
  • 底层简介
    首先判断元素的hashCode()值是否相同,不相同则直接存储,相同则继续执行equals()
    如果equals()返回结果为true说明元素相同,则不存储,如果返回结果为false说明元素不相同,则存储
LInkedHashMap
  • 底层数据结构由哈希表和链表组成
  • 哈希表保证元素的唯一性,链表保证元素有序(存入和取出一致)
Hashtable 与 HashMap 的比较
  • Hashtable:哈希表, 同步,线程安全,效率低,不允许null键和null值
  • Hashtable子类Properties:属性集,键和值都是字符串
  • HashMap:哈希表, 不同步,线程不安全,效率高,允许null键和null值
  • HashMap子类LinkedHashMap:基于链表加哈希表,可以保证map集合有序(存入和取出的顺序一致)
TreeMap
  • 底层数据结构是红黑树(一种自平衡的二叉树结构)
  • 二叉树结构,不同步,可以对map集合中的键进行排序

元素的排序

  • 元素的唯一性:
    依靠元素比较的返回值是否为0来决定
  • 元素的有序性:
    1. 自然排序(元素具备比较性)
      无参构造new TreeSet<T>()使用的是自然排序,让元素所属的类实现自然排序接口,底层用CompareTo()方法(Comparable接口)来做数据校验
    2. 比较器排序(集合具备比较性)
      构造方法new TreeSet<T>(Comparator comparator)接收一个比较器接口(该接口的子类对象),底层使用Compare()方法来做数据校验
重写比较器进行排序
public class ComparatorByLength implements Comparator {
    
    @Override
    public int compare(Object o1, Object o2) {
        String s1 = (String) o1;
        String s2 = (String) o2;
        int temp = s1.length() - s1.length();
        return temp == 0 ? compareTo(s2) : temp;
    }
}

相关文章

  • 映射、元组、集合

    映射 元组 集合 集合之seq 集合之set 集合之map

  • Java中Map接口

    Map 集合和 Collection 集合不同,Map 集合是基于键(key)/值(value)的映射,Colle...

  • 集合 -- Map映射

    Map映射 Map集合的数据结构仅仅针对键有效,和值无关 存储的是键值对元素,键是唯一的,值可重复 HashMap...

  • Map映射集合

    Map集合框架:java.util.Map :1、定义:具有 key(键)-value(值)映射关系的集合。2、M...

  • Map映射集合

    Map映射集合 学习其子类 HashMap: HashMap是一个以键值对方式存储数据的集合,键必须唯一,不能保证...

  • 2020-06-29Map集合

    Map集合 Map集合概述①Interface Map K:键的类型 : 值的类型。②将键映射到值的对象...

  • Java基础笔记18

    18.01_集合框架(Map集合概述和特点) A:Map接口概述查看API可以知道:将键映射到值的对象一个映射不能...

  • java基础系列07--集合(3)

    JAVA集合三 Map集合 java.util 下的接口Map,将键映射到值的对象。一个映射不能包含重...

  • Java基础系列31-双列 Map集合、Properties集合

    一. Map集合 Map集合将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。 1.1 创...

  • Java集合框架之Map

    1 Map集合N016 1.1Map接口 【 • 实现Map接口的集合类用来存储"键-值"映射对。 • JDK...

网友评论

      本文标题:集合 -- Map映射

      本文链接:https://www.haomeiwen.com/subject/urfmzftx.html