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. js 符号转换 html代码

    S转换HTML转义符 //去掉html标签 function removeHtmlTab(tab) { return tab.replace(/<[^<>]+?>/g,''); ...

  2. 【洛谷P3391】文艺平衡树——Splay学习笔记(二)

    题目链接 Splay基础操作 \(Splay\)上的区间翻转 首先,这里的\(Splay\)维护的是一个序列的顺序,每个结点即为序列中的一个数,序列的顺序即为\(Splay\)的中序遍历 那么如何实现 ...

  3. 第12组 Beta冲刺(2/5)

    Header 队名:To Be Done 组长博客 作业博客 团队项目进行情况 燃尽图(组内共享) 由于这两天在修严重Bug,故项目没有新的进展,燃尽图没有变化 展示Git当日代码/文档签入记录(组内 ...

  4. mysql 提示ssl问题

    问题信息如下: rements SSL connection must be established by default if explicit option isn't set. For comp ...

  5. Python调用win32 API绘制正弦波

    Python调用win32 API新建窗口与直接创建窗口的流程相同 流程:注册窗口→创建窗口→显示窗口→更新窗口→消息循环 代码: # -*- coding: utf-8 -*- import win ...

  6. 2019暑假Java学习笔记(二)

    目录 基础语法(下) 流程控制 if语句 switch语句 while语句和do-while语句 for语句 break关键字 continue关键字 数组 一维数组 二维数组 用户输入操作 练习题: ...

  7. ubuntu之路——day12.1 不用tf和torch 只用python的numpy在较为底层的阶段实现简单神经网络

    首先感谢这位博主整理的Andrew Ng的deeplearning.ai的相关作业:https://blog.csdn.net/u013733326/article/details/79827273 ...

  8. Python3爬取王者官方网站英雄数据

    爬取王者官方网站英雄数据 众所周知,王者荣耀已经成为众多人们喜爱的一款休闲娱乐手游,今天就利用python3 爬虫技术爬取官方网站上的几十个英雄的资料,包括官方给出的人物定位,英雄名称,技能名称,CD ...

  9. dubbo架构角色

    角色 Dubbo有5个参与者:其中Monitor.Registry不是必须的 Provider 暴露服务的服务提供方 Consumer 调用远程服务的服务消费方(负载均衡) Registry 服务注册 ...

  10. [译]如何在红帽系统(RHEL)上源码安装python3?

    原文来源: https://stackoverflow.com/questions/8087184/installing-python-3-on-rhel 很容易手动安装. 1.下载对应的python ...