HashMap

HashMap 是一个散列表,它存储的内容是键值对(key-value)映射。

HashMap 实现了 Map 接口,根据键的 HashCode 值存储数据,具有很快的访问速度,最多允许一条记录的键为
null,不支持线程同步。

HashMap 是无序的,即不会记录插入的顺序。

HashMap 继承于AbstractMap,实现了 Map、Cloneable、java.io.Serializable 接口。

HashMap 中的元素实际上是对象,一些常见的基本类型可以使用它的包装类。

基本类型 引用类型
boolean Boolean
byte Byte
int Integer
short Short
long Long
float Float
double Double
char Character

常用增删改方法

put(Object key,Object value) 添加
putAll(map) 添加map所有元素到this
remove(Object key)  删除
put(Object key,Object value) 修改
get(Object key) 查询
size()  长度
遍历
keySet()    获取key返回Set values() 获取value返回CollectionentrySet()   获取Map
clear()     清空
isEmpty()   判断是否为空
clone()     复制一份 hashMap
putIfAbsent()   如果 hashMap 中不存在指定的键,则将指定的键/值对插入到 hashMap 中。
containsKey()   检查 hashMap 中是否存在指定的 key 对应的映射关系。
containsValue() 检查 hashMap 中是否存在指定的 value 对应的映射关系。
replace()   替换 hashMap 中是指定的 key 对应的 value。
replaceAll()    将 hashMap 中的所有映射关系替换成给定的函数所执行的结果。
getOrDefault()  获取指定 key 对应对 value,如果找不到 key ,则返回设置的默认值
forEach()   对 hashMap 中的每个映射执行指定的操作。
entrySet()  返回 hashMap 中所有映射项的集合集合视图。
values()    返回 hashMap 中存在的所有 value 值。
merge() 添加键值对到 hashMap 中
compute()   对 hashMap 中指定 key 的值进行重新计算
computeIfAbsent()   对 hashMap 中指定 key 的值进行重新计算,如果不存在这个 key,则添加到 hasMap 中
computeIfPresent()  对 hashMap 中指定 key 的值进行重新计算,前提是该 key 存在于 hashMap 中。

添加

public void test3(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);map.put("4",159);
}

删除

 public void test4(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);//删除key值为"1"元素map.remove("1");//清空 删除所有元素map.clear();}

修改覆盖

public void test5(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);//修改 key值为"1"的元素value为456map.put("1",456);
}

返回指定元素

    public void test(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);//通过主键返回指定元素valueInteger integer2 = map.get("1");System.out.println(integer2);}
public void test(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);//返回所有键值对Set<Map.Entry<String, Integer>> entries = map.entrySet();//返回所有key键Set<String> strings = map.keySet();//返回所有valueCollection<Integer> values = map.values();}
public void test8(){Map<String,Integer> map = new HashMap();map.put("1",123);map.put("2",147);map.put("3",456);//长度大小map.size();//判空 依据是size()是否为0map.isEmpty();}

遍历

@Testpublic void test3(){HashMap map = new HashMap();map.put("TOM","3");map.put("SEt",1);map.put("12",1);map.put("3",1);map.put("rr4",1);//for eachSet set = map.keySet();获取key Setfor (Object obj : set){System.out.println(obj);}//输出value值Collection list = map.values();//获取value列表for (Object obj : list){System.out.println(obj);}//通过Entry遍历Set set1 = map.entrySet();//获取Map中的EntryIterator iterator = set1.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}//迭代器遍历Set set2 = map.keySet();Iterator iterator1 = set2.iterator();while (iterator1.hasNext()){Object next = iterator1.next();Object value = map.get(next);System.out.println(next +"="+value);}}

特别的

HashMap线程不安全,但效率高 。
JDK7及之前使用数组+链表形式存储数据。
JDK8之后为数组+链表+红黑树
linkedHashMap用于频繁的遍历,使用此结构比HashMap多一个指针

—————————————————分割线———————————————————

HashMap底层原理&源码分析

面试高频——HashMap底层实现原理与源码剖析(JDK7、8对比)

Java SE系列笔记——HashMap相关推荐

  1. 当年我们一起追过的Java,Java SE 个人笔记

    目录 JDK的安装和配置运行Java程序 java基本语法 面向对象 异常 多线程l API(Application Programming Interface)各种功能的类说明 集合类 IO输入输出 ...

  2. JAVA SE基础笔记

    第一天  JDK安装.快捷键.JAVA语言特点 1.Java语言的概述 1.1 Java语言的背景 Java语言诞生于1995年,在编程语言排行榜占据重要的地位. Java语言之父是高斯林,以前隶属于 ...

  3. Java SE 学习笔记5 Java阶段复习

    计算机.Java基础 一.计算机 1.硬件介绍 2.中央处理器 3.比特(bit)和字节(byte) 4.内存 5.存储设备 6.输入和输出设备 二.Java介绍 1.常用的dos命令 2.java语 ...

  4. java se系列(一)开发前奏

    1. 软硬件知识 电子计算机:俗称电脑,是一种能够按照程序运行,自动.高速处理海量数据的现代化智能电子设备.由硬件和软件所组成,没有安装任何软件的计算机称为裸机 cpu:是一台计算机的运算核心和控制核 ...

  5. JAVA SE 学习笔记

    笔记 一·Java程序基础 代码练习合集 1.Hello,world 2.BMI 3.Grade 4.InputNum 5.Gamecaiquan 6.Main 7.Reserve_arrays 8. ...

  6. Java Collection系列之HashMap、ConcurrentHashMap、LinkedHashMap的使用及源码分析

    文章目录 HashMap HashMap的存储结构 初始化 put & get put元素 get元素 扩容 遍历Map jdk1.8中的优化 ConcurrentHashMap jdk1.7 ...

  7. Java高级语法笔记-HashMap

    哈希表HashMap中可以存储N个对象,每个对象由一个唯一的Key值关联. 哈希表主要用于快速查找 那么,怎么样查找才算是"快速"? 假设有1000个Student对象, (1) ...

  8. JAVA SE学习笔记(七):终章:Java程序设计基础笔记(全10万字)

    Java程序设计入门 ​                                              copyright © 2020 by 宇智波Akali 目录 文章目录 第1章 J ...

  9. java se系列(十二)集合

    1.集合 1.1.什么是集合 存储对象的容器,面向对象语言对事物的体现,都是以对象的形式来体现的,所以为了方便对多个对象的操作,存储对象,集合是存储对象最常用的一种方式.集合的出现就是为了持有对象.集 ...

  10. java se初学笔记(初阶到高阶)

    class是关键字,用于定义类,一个类只能有一个主函数:修饰类的关键字:public,final,private(仅内部类); 每个对象都有自己的字符串表达形式: 关键字所有字母都是小写: 打印双引号 ...

最新文章

  1. python收入波动告警分析_使用Python/Pandas分析告警日志数据
  2. 【SpringBoot】如何在静态工具类中注入mapper?
  3. 21行代码AC_ 试题H: 修改数组【解题报告】
  4. Hadoop学习笔记03_Hive练习
  5. 屯题 (bestcoder #62~#75)
  6. VA Code编写html(1)
  7. ThinkPHP链接 PgSQL
  8. 最长不下降子序列的长度
  9. CentOS7安装dnf
  10. 卸载所有supervisor残留_拯救C盘!这个良心的卸载工具还是免费的?!
  11. 01-什么是网络爬虫
  12. 05--SpringBoot之上传文件
  13. the info.plist in the package must contain the CFBundleShortVersionString key.
  14. 这特么是啥系列之----HSF求求你别秀了
  15. (实战)Node.js 实现抢票小工具短信通知提醒
  16. 典型相关分析(Canonical correlation analysis)(二):原始变量与典型变量之间的相关性 、典型相关系数的检验
  17. Flutter的菜鸟教程
  18. 使用 VMware 安装 CentOS(一)
  19. 【无法找到FeignClient的bean】 Consider defining a bean of type ‘xxx‘ in your configuration.
  20. Linux中tar 命令压缩时报错 tar: Removing leading `/‘ from member names

热门文章

  1. 你的短信接口真的安全吗?
  2. 家用NAS有什么用?充分挖掘你的NAS功能
  3. C# datagridview / datatable 导出带表头的excel的数据
  4. 爬虫——Scrapy框架案例二:阳光问政平台
  5. 国家集训队 种树 题解
  6. 在百度实习的100天
  7. python3写入txt_[Python3] 写入文本文件[TZZ]
  8. 2合1笔记本 android,华为二合一笔记本支持Android可能是鸡肋
  9. 六大iT公司的组织结构
  10. pdf覆盖图片 Java_Java 添加、替换、删除PDF中的图片