文章目录

  • HashMap类
  • LinkedHashMap类
  • TreeMap类
  • Hashtable类
  • Properties类


HashMap类


1、HashMap类概述

HashMap是 Map 接口使用频率最高的实现类,允许使用null键和null值,与HashSet一样,不保证映射的顺序。

所有的key构成的集合是Set:无序的、不可重复的。所以,key所在的类要重写
equals()hashCode()
所有的value构成的集合是Collection:无序的、可重复的。所以,value所在的类
要重写equals()

一个key-value构成一个entry,所有的entry构成的集合是Set:无序的、不可重复的。

HashMap判断两个 key 相等的标准:两个 key 通过 equals() 方法返回 true,
hashCode() 值也相等。
HashMap判断两个 value 相等的标准:两个 value 通过 equals() 方法返回 true。


2、HashMap的存储结构(底层实现原理)

HashMap map = new HashMap()

(以JDK1.7说明)
在实例化以后,底层就创建了长度为16的一维数组Entry[] table

map.put(key1,value1)

首先,调用key1所在类的hashCode()计算key1哈希值,此哈希值经过某种算法计算以后,得到在Entry[]数组中的存放位置。

如果此位置上的数据为空,此时的key1-value1添加成功。----情况1
如果此位置上的数据不为空(意味着此位置上存在一个或多个数据(以链表形式存在)),则继续比较key1和已经存在的一个或多个数据的哈希值:

如果key1的哈希值与已经存在的数据的哈希值都不相同,此时key1-value1添加成功。----情况2
如果key1的哈希值和已经存在的某一个数据key2-value2的哈希值相同,继续比较:

调用key1所在类的equals(key2)
如果equals()返回false:此时key1-value1添加成功。----情况3
如果equals()返回true:使用value1替换value2。

补充:关于情况2和情况3,此时key1-value1和原来的数据以链表的方式存储。
在不断的添加过程中,会涉及到扩容问题,默认的扩容方式:扩容为原来容量的2倍,并将原有的数据复制过来。

JDK1.8相较于JDK1.7在底层实现方面的不同:
new HashMap(),底层还没有创建一个长度为16的数组
②JDK1.8底层的数组是: Node[],而非Entry[]
③首次调用put()方法时,底层才创建长度为16的数组Node[]
④形成链表结构时,新添加的key-value对在链表的尾部(七上八下)
⑤JDK1.7底层结构只有“数组+链表”,JDK1.8中底层结构为“数组+链表+红黑树”。
当数组的某一个索引位置上的元素以链表形式存在的数据个数>8且当前数组的长度>64时,此时此索引位置上的所有数据改为使用红黑树存储。



3、HashMap源码中的重要常量

DEFAULT_INITIAL_CAPACITY: HashMap的默认容量,16
MAXIMUM_CAPACITY: HashMap的最大支持容量,2^30
DEFAULT_LOAD_FACTOR:HashMap的默认加载因子,0.75
TREEIFY_THRESHOLD:Bucket中链表长度大于该默认值8,转化为红黑树
UNTREEIFY_THRESHOLD:Bucket中红黑树存储的Node小于该默认值6,转化为链表
MIN_TREEIFY_CAPACITY:桶中的Node被树化时最小的hash表容量。(当桶中Node的数量大到需要变红黑树时,若hash表容量小于MIN_TREEIFY_CAPACITY时,此时应执行resize扩容操作这个MIN_TREEIFY_CAPACITY的值至少是TREEIFY_THRESHOLD的4倍为64。)
table:存储元素的数组,总是2的n次幂
entrySet:存储具体元素的集
size:HashMap中存储的键值对的数量
modCount:HashMap扩容和结构改变的次数。
threshold:扩容的临界值,=容量*填充因子
loadFactor:填充因子



LinkedHashMap类


LinkedHashMap 是 HashMap 的子类

在HashMap存储结构的基础上,使用了一对双向链表来记录添加元素的顺序

与LinkedHashSet类似,LinkedHashMap 可以维护 Map 的迭代顺序:迭代顺序与 Key-Value 对的插入顺序一致



TreeMap类


1、TreeMap类概述

TreeMap存储 Key-Value 对时,需要根据 key 进行排序。TreeMap 可以保证所有的 Key-Value 处于有序状态。

TreeSet底层使用红黑树结构存储数据。

TreeMap 的 Key 的排序:
①自然排序:TreeMap 的所有的 Key 必须实现 Comparable 接口,而且所有
的 Key 应该是同一个类的对象,否则将会抛出 ClasssCastException。
②定制排序:创建 TreeMap 时,传入一个 Comparator 对象,该对象负责对
TreeMap 中的所有 key 进行排序,此时不需要 Map的Key实现Comparable接口。

TreeMap判断两个key相等的标准:两个key通过compareTo()方法或者compare()方法返回0。


2、自然排序

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;/*** @Author: Yeman* @Date: 2021-09-22-22:59* @Description:*/class user implements Comparable{String name;int age;public user(String name, int age) {this.name = name;this.age = age;}@Overridepublic String toString() {return "user{" +"name='" + name + '\'' +", age=" + age +'}';}@Overridepublic int compareTo(Object o) {if (o instanceof user){user other = (user) o;Integer nameResult = this.name.compareTo(other.name);if (nameResult == 0){return Integer.compare(this.age,other.age);}else return nameResult;}else throw new RuntimeException("类型不匹配");}
}public class TreeMapTest {public static void main(String[] args) {Map map = new TreeMap();map.put(new user("Tom",22),1);map.put(new user("Jim",18),2);map.put(new user("Marry",20),3);map.put(new user("Lily",16),4);map.put(new user("Tom",18),5);Set set = map.entrySet();Iterator iterator = set.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}}
}


3、定制排序

import java.util.*;/*** @Author: Yeman* @Date: 2021-09-22-22:59* @Description:*/class user {String name;int age;public user(String name, int age) {this.name = name;this.age = age;}@Overridepublic String toString() {return "user{" +"name='" + name + '\'' +", age=" + age +'}';}
}public class TreeMapTest {public static void main(String[] args) {Comparator comparator = new Comparator() {@Overridepublic int compare(Object o1, Object o2) {if (o1 instanceof user && o2 instanceof user) {user user1 = (user) o1;user user2 = (user) o2;Integer nameResult = user1.name.compareTo(user2.name);if (nameResult == 0) return Integer.compare(user1.age, user2.age);else return nameResult;} else throw new RuntimeException("类型不匹配");}};Map map = new TreeMap(comparator);map.put(new user("Tom",22),1);map.put(new user("Jim",18),2);map.put(new user("Marry",20),3);map.put(new user("Lily",16),4);map.put(new user("Tom",18),5);Set set = map.entrySet();Iterator iterator = set.iterator();while (iterator.hasNext()) {System.out.println(iterator.next());}}
}



Hashtable类

Hashtable是个古老的 Map 实现类,JDK1.0就提供了。不同于HashMap,
Hashtable是线程安全的。

Hashtable实现原理和HashMap相同,功能相同。底层都使用哈希表结构,查询
速度快,很多情况下可以互用。

与HashMap不同,Hashtable 不允许使用 null 作为 key 和 value。
与HashMap一样,Hashtable 也不能保证其中 Key-Value 对的顺序。

Hashtable判断两个key相等、两个value相等的标准,与HashMap一致。



Properties类

Properties 类是 Hashtable 的子类,该对象用于处理属性文件,由于属性文件里的 key、value 都是字符串类型,所以 Properties 里的 key 和 value 都是字符串类型

存取数据时,建议使用setProperty(String key,String value)方法和getProperty(String key)方法

Properties pros = new Properties();
pros.load(new FileInputStream("jdbc.properties"));
String user = pros.getProperty("user");
System.out.println(user);

Java集合(7)--Map接口的实现类HashMap、LinkHashMap、TreeMap和Properties相关推荐

  1. java hashedmap_Java基础 - Map接口的实现类 : HashedMap / LinkedHashMap /TreeMap 的构造/修改/遍历/ 集合视图方法/双向迭代输出...

    import java.util.*; /**一:Collection接口的 * Map接口: HashMap(主要实现类) : HashedMap / LinkedHashMap /TreeMap ...

  2. Map接口的实现类HashMap的操作

    3中遍历HashMap方式 package C12_21;import java.util.Collection; import java.util.HashMap; import java.util ...

  3. 集合之六:Map接口

    Map接口概述 Map接口中的集合和Collection接口中的集合在存储数据的格式上有很大的不同,Map接口下的内容是以<K , V> ,键值对的形式存储的,我们查询API,Map接口的 ...

  4. Java集合篇:Map接口、Map接口的实现类、Collections集合工具类

    目录 一.Map接口 1.1 Map接口概述 1.2 Map接口常用功能 二.Map接口的实现类 2.1 Map实现类之一:HashMap 2.1.1 HashMap概述 2.1.2 HashMap的 ...

  5. JAVA集合Connection接口和Map接口常用的类及区别

    JAVA集合详解 文章目录 JAVA集合详解 前言 一.集合是什么? 1. 集合类 2.集合和数组的区别: 二.使用步骤 一.Connection接口(单列集合) 1.List和Set的优缺点 2.总 ...

  6. 集合框架详解之Set、Map接口与实现类

    集合框架 1.Set集合 1.1Set集合概述 Set实现类:HashSet类.TreeSet类 特点:无序.无下标.元素不可重复 方法:全部继承自Collection中的方法 1.11 Set接口的 ...

  7. Java讲课笔记23:Map接口及其实现类

    文章目录 零.本讲学习目标 1.了解Map集合的常用方法 2.掌握HashMap和TreeMap的使用 3.掌握Properties集合的使用 4.掌握Map集合遍历 一.Map接口 1.Map接口概 ...

  8. Collection 和 Map接口及其实现类总结

    Collection 和 Map接口及其实现类总结 Collection接口 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Ele ...

  9. Collection集合类和Map接口各实现类详解

    Java的集合类(collection接口和Map) 一.集合概述 集合:集合是java中提供的一种容器,可以用来存储多个数据. 集合和数组既然都是容器,它们有啥区别呢? 数组的长度是固定的.集合的长 ...

最新文章

  1. Oracle DBLink的简单运用
  2. namespace命名空间的使用
  3. FunTester框架Redis压测预备
  4. 集线器、交换机和路由器之间的区别
  5. 史秀峰计算机网络技术与应用第二版,史秀峰版《计算机网络技术与应用》期中测试.doc...
  6. windows认证密码抓取
  7. 优化方法总结(梯度下降法、牛顿法、拟牛顿法等)
  8. 【Windows 10】U盘量产
  9. 程序员面试需要出示身份证和毕业证原件吗
  10. 鸿蒙系统屏幕解锁问题,鸿蒙系统解锁卡退黑屏
  11. 【实验】【视图】使用v$bgprocess视图获得所有后台进程信息
  12. php三D立体模拟,【HTML5】3D模型--百行代码实现旋转立体魔方实例
  13. gitgerrit配置
  14. SR研究(1)RCAN论文阅读上
  15. 夜半加班之附魔吃药篇!
  16. 更新Pycharm中的pip版本及第三方包的安装问题
  17. 【基于AnyLogic的管理仿真系统】
  18. 导入keras训练好的模型报错解决OSError: Unable to open file (unable to open file: name = ‘model_3.h5’)
  19. Visual Studio 2022 IDE 下载安装与环境配置,C语言/C++集成环境配置,VS2022。详细环境配置教程,最适合写c语言的编译器
  20. arcgis导入坐标点转面_ArcGIS学习记录—Arcgis中点、线、面的相互转换方法

热门文章

  1. androidtabhost缓存_FragmentTabHost布局的使用及优化方式
  2. Java对象内存图一
  3. QPW 行政区划字典表(td_area)
  4. windows系统SSH证书设置
  5. 淮阴工学院计算机期末考选择题题库,淮阴工学院PLC试题库.doc
  6. 增加第三方插件_AE插件排行!!
  7. websocket没准备好如何解决_那些很重要,但是不常用的技术,websocket
  8. access update语句执行_SQL Server与Access数据库sql语法十大差异
  9. 九九乘法表代码口述_利用随机函数实现座次表的随机排座
  10. 计算机编程试讲教案,2016教师资格证面试试讲高中信息技术教案:QBASIC分支结构程序...