HashMap的概念

HashMap底层实现了哈希表,这是一种非常重要的数据结构,对于以后我们理解很多技术都有帮助,例如 redis数据库的核心技术和HashMap一样,因此,非常有必要让大家理解。

HashMap的数据结构由数组和链表来实现对数据的存储,它们各有特点:

  1. 数组:占用空间连续,寻址容易,查询速度快。但是增删效率低。
  2. 链表:占用空间不连续,寻址困难,查询速度慢。但是增删效率高。

将数据与链表的优点结合起来,就得到了我们的哈希表。因此哈希表的本质就是数组+链表。

HashMap的常用方法

关键点摘要:

  • 泛型可以使用基本数据类型,也可以使用引用数据类型
  • 使用put填入同一个key,后面的key对应的值会替换前面的key对应的值
  • 替换replace与remove方法都有两种形式,返回被删除/替换的值和返回boolean。
package _20191211;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Set; /**
* HashMap部分方法测试
* @author TEDU
*
*/
public class HashMapTest {
public static void main(String[] args) {
Map<Integer,String> myMap = new HashMap<>();
myMap.put(1,"one");
myMap.put(2,"two");
myMap.put(3,"three");
System.out.println(myMap.get(1));//返回key对应的值
System.out.println(myMap.containsKey(3));//是否包含指定的key
System.out.println(myMap.containsValue("One"));//是否包含指定的值
//移除方法
System.out.println(myMap.remove(2));//移除指定的key,返回其值
System.out.println(myMap);
System.out.println(myMap.remove(1,"one"));//移除指定的key与value,返回boolean
System.out.println(myMap);
//key不能重复,若重复,会将该key对应的value覆盖,不可以将此方法做替换方法用,不便于阅读
myMap.put(3,"三");
System.out.println(myMap);
//替换方法 replace 只能替换已存在的键值对
System.out.println(myMap.replace(3,"three"));//返回被替换的值
System.out.println(myMap.replace(1,"one"));//只能替换已存在的
System.out.println(myMap.replace(3, "three", "叁"));//返回布尔值
System.out.println(myMap);
//putAll 将一个map添加到另一个map
Map<Integer,String> myMap2 = new HashMap<>();
myMap2.put(4, "肆");
myMap.putAll(myMap2);
System.out.println(myMap);
//返回key的set集合
Set<Integer> keySet = myMap.keySet();
System.out.println(keySet);
//返回value的集合
Collection values = myMap.values();
System.out.println(values); }
}

  

一个例子:

使用HashMap存储一个公司的员工信息。(泛型可以使用基本数据类型,也可以使用引用数据类型)

package _20191211;

import java.util.HashMap;
import java.util.Map; public class HashMapTest02 {
public static void main(String[] args) {
Employee ep1 = new Employee("小白",20000);
Employee ep2 = new Employee("小黑",10000);
Map<Integer,Employee> mp = new HashMap<>();
mp.put(1001,ep1);
mp.put(1002,ep2);
System.out.println(mp); }
} class Employee{
private String name;
private int salary;
public Employee(String name, int salary) {
super();
this.name = name;
this.salary = salary;
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getSalary() {
return salary;
}
public void setSalary(int salary) {
this.salary = salary;
}
@Override
public String toString() {
return " 姓名:"+name+" 薪水:"+salary;
}
}

  

HashMap与HashTable的区别

HashMap:线程不安全,效率高,允许key与value为null

HashTable:线程安全,效率低,不允许key与value为null

47 容器(六)——HashMap的更多相关文章

  1. 给jdk写注释系列之jdk1.6容器(4)-HashMap源码解析

    前面了解了jdk容器中的两种List,回忆一下怎么从list中取值(也就是做查询),是通过index索引位置对不对,由于存入list的元素时安装插入顺序存储的,所以index索引也就是插入的次序. M ...

  2. 六.HashMap HashTable HashSet区别剖析总结

    HashMap.HashSet.HashTable之间的区别是Java程序员的一个常见面试题目,在此仅以此博客记录,并深入源代码进行分析: 在分析之前,先将其区别列于下面: 1.HashSet底层采用 ...

  3. Java容器:HashMap和HashSet解析

    转载请注明出处:jiq•钦's technical Blog 一.HashMap HashMap,基于散列(哈希表)存储"Key-Value"对象引用的数据结构. 存入的键必须具备 ...

  4. Java容器:HashMap连环炮

    本文来源于:https://mp.weixin.qq.com/s/oRx-8XXbgage9Hf97WrDQQ, 公众号:安琪拉的博客 前言 HashMap应该算是Java后端工程师面试的必问题,因为 ...

  5. Java中的容器(集合)之HashMap源码解析

    1.HashMap源码解析(JDK8) 基础原理: 对比上一篇<Java中的容器(集合)之ArrayList源码解析>而言,本篇只解析HashMap常用的核心方法的源码. HashMap是 ...

  6. Map,HashMap

    Map(映射),又称为字典(Dictionary),是由关键字(Key)及其对应的元素值(Value)所组成的元素单元(Element)的表单式集合. 通常,对于Map而言,使用给定的Key,可以迅速 ...

  7. App架构师实践指南六之性能优化三

    App架构师实践指南六之性能优化三 2018年08月02日 13:57:57 nicolelili1 阅读数:190   内存性能优化1.内存机制和原理 1.1 内存管理内存时一个基础又高深的话题,从 ...

  8. 基于jdk1.8的HashMap源码学习笔记

    作为一种最为常用的容器,同时也是效率比较高的容器,HashMap当之无愧.所以自己这次jdk源码学习,就从HashMap开始吧,当然水平有限,有不正确的地方,欢迎指正,促进共同学习进步,就是喜欢程序员 ...

  9. Map 综述(一):彻头彻尾理解 HashMap

    转载自:https://blog.csdn.net/justloveyou_/article/details/62893086 摘要: HashMap是Map族中最为常用的一种,也是 Java Col ...

随机推荐

  1. 持续集成学习7 jenkins自动化代码构建

    一.整体功能 1.触发上下游构建 2.我们在触发一个job的时候顺便丢一些参数过去,这些参数有可能是我这次编译过程中产生的一些地址,版本号或动态的一些东西丢到下游作为下游的构建参数 3.不同种类的视图

  2. Windows用户模式调试内部组件

    简介 允许用户模式调试工作的内部机制很少得到充分的解释.更糟糕的是,这些机制在Windows XP中已经发生了根本性的变化,当许多支持被重新编写时,还通过将ntdll中的大多数例程作为本地API的一部 ...

  3. 开源项目 07 AutoMapper

    using AutoMapper; using Newtonsoft.Json; using System; using System.Collections.Generic; using Syste ...

  4. 搭建的一套vue打包方案,方便记录一下

    package.json 配置如下: { "name": "rise-vue", "version": "1.0.0", ...

  5. 70: libreoj #2424 区间dp

    $des$ $sol$ $f_{i, j, k} => a => [1, i], b => [1, j], a_i = b_j | a_i != b_j , a_i => 0 ...

  6. 怎么样使element ui 的table某列变色

    第一步.在el-table里面加上:row-style="rowClass" <el-table :data="targetCarList" border ...

  7. 20189220 余超《Linux内核原理与分析》第一周作业

    实验一 Linux系统简介 通过实验一主要是学习到了Linux 的历史简介,linux与windows之间的区别,主要是免费和收费,软件和支持,安全性,使用习惯,可制定性,应用范畴等.linux具有稳 ...

  8. Java自己实现HTTP服务器来理解GET和POST区别

    GET请求和POST请求有什么区别?GET请求的参数在URL的问号后面显示,而POST参数不在URL上:POST可以比GET请求更大的数据…一般的回答都是这样.   但是作为一个高端大气上档次的程序员 ...

  9. linux学习(1):linux命令大全

    Linux命令 目录 1       文件管理... 5 1.1          basename. 5 1.2          cat 5 1.3          cd. 5 1.4      ...

  10. Shell获取字符串长度的多种方法总结

    摘自:https://www.jb51.net/article/121290.htm 前言 我们在日常工作中,对于求字符串操作在shell脚本中很常用,实现的方法有很多种,下面就来给大家归纳.汇总了求 ...