HashMap的一些学习
1.equals和==的对比
==用于比较引用和比较基本数据类型时具有不同的功能:
A:比较基本数据类型,如果两个值相同,则结果为true
而在比较引用时,如果引用指向内存中的同一对象,结果为true;
equals()作为方法,实现对象的比较。由于==运算符不允许我们进行覆盖,也就是说它限制了我们的表达。
因此我们复写equals()方法,达到比较对象内容是否相同的目的。而这些通过==运算符是做不到的。
String s1=new String("abc");
String s2=new String("abc");
String s3=new String(s1);
System.out.println(s1==s2);
System.out.println(s1==s3);
System.out.println(s1.equals(s2));
运行结果为:false、false、true
2.HashMap的数据结构和HashMap的存取实现
1):首先HashMap里面实现一个静态内部类Entry,其重要的属性有 key , value, next,
从属性key,value我们就能很明显的看出来Entry就是HashMap键值对实现的一个基础bean,
我们上面说到HashMap的基础就是一个线性数组,这个数组就是Entry[],Map里面的内容都
保存在Entry[]里面。
//存储时:
int hash = key.hashCode();// 这个hashCode方法这里不详述,只要理解每个key的hash是一个固定的int值
int index = hash % Entry[].length;
Entry[index] = value;
//取值时:
int hash = key.hashCode();
int index = hash % Entry[].length;
return Entry[index];
这里HashMap里面用到链式数据结构的一个概念。上面我们提到过Entry类里面有一个next属性,
作用是指向下一个Entry。打个比方, 第一个键值对A进来,通过计算其key的hash得到的index=0,
记做:Entry[0] = A。一会后又进来一个键值对B,通过计算其index也等于0,现在怎么办?
HashMap会这样做:B.next = A,Entry[0] = B,如果又进来C,index也等于0,那么C.next = B,
Entry[0] = C;这样我们发现index=0的地方其实存取了A,B,C三个键值对,他们通过next这个属性链接在一起。
所以疑问不用担心。也就是说数组中存储的是最后插入的元素。到这里为止,HashMap的大致实现,我们应该已经清楚了。
也就是说数组中存储的是最后插入的元素
3.HashMap与HashTable的区别:
A:两者最主要的区别在于Hashtable是线程安全,而HashMap则非线程安全
B:HashMap可以使用null作为key,不过建议还是尽量避免这样使用。HashMap以null作为key时,
总是存储在table数组的第一个节点上。而Hashtable则不允许null作为key。
C:HashMap的初始容量为16,Hashtable初始容量为11,两者的填充因子默认都是0.75。
4.线程数组HashMap为什么是线程不安全的?
HashMap底层是一个Entry数组,当产生hash冲突的时候,hashmap是采取链表的方法来解决的,在对应的数组位置寄存链表的
头结点。对链表而言,新加入的节点会从头结点加入。
在hashmap做put操纵的时候会调用到以上的方法。当初假如A线程和B线程同时对同一个数组位置调用addEntry,两个线程会同时得到当初的头结点,
然后A写入新的头结点以后,B也写入新的头结点,那B的写入操纵就会覆盖A的写入操纵造成A的写入操纵丧失
5.Sql中--delete、truncate 、Drop删除表的区别:
--delete from 表名
--1>只是删除表中某些数据,表结构还在.。
--2>Delete 可以带where子句来删除一部分数据,例如 DELETE FROM Student WHERE sAge > 20
--3>自动编号不恢复到初始值。
--truncate table 表名
--1>truncate语句不能跟where条件,无法根据条件来删除,只能全部删除数据。
--2>自动编号恢复到初始值。
--3>使用truncate删除表中所有数据要比delete效率高的多,因为truncate操作采用按最小方式来记录日志.
--4>truncate删除数据,不触发delete触发器。
--drop table 表名
--1>删除表本身,即表中数据和表结构(列、约束、视图、键)全部删除。
HashMap的一些学习的更多相关文章
- hashMap源码学习记录
hashMap作为java开发面试最常考的一个题目之一,有必要花时间去阅读源码,了解底层实现原理. 首先,让我们看看hashMap这个类有哪些属性 // hashMap初始数组容量 static fi ...
- 基于jdk1.8的HashMap源码学习笔记
作为一种最为常用的容器,同时也是效率比较高的容器,HashMap当之无愧.所以自己这次jdk源码学习,就从HashMap开始吧,当然水平有限,有不正确的地方,欢迎指正,促进共同学习进步,就是喜欢程序员 ...
- HashMap、HashTable学习
HashMap: HashMap 继承于AbstractMap,实现了Map.Cloneable.java.io.Serializable接口. HashMap 的实现不是同步的,这意味着它不是线程安 ...
- HashMap和HashTable 学习
1. HashMap 1) hashmap的数据结构 Hashmap是一个数组和链表的结合体(在数据结构称“链表散列“),如下图示: 当我们往hashmap中put元素的时候,先根据key的hash ...
- java源码--HashMap扩容机制学习
待完成 Java中hash算法细述 https://blog.csdn.net/majinggogogo/article/details/80260400 java HashMap源码分析(JDK8) ...
- 【jdk源码3】HashMap源码学习
可以毫不夸张的说,HashMap是容器类中用的最频繁的一个,而Java也对它进行优化,在jdk1.7及以前,当将相同Hash值的对象以key的身份放到HashMap中,HashMap的性能将由O(1) ...
- HashMap源码学习
HashMap就是将key做hash算法,然后将hash值映射到内存地址,直接取得key所对应的数据. 关于hash算法的原理知识在之前的博客中有讲到:哈希表之一初步原理了解. 在Java中的Hash ...
- HashMap 的深入学习
Java为数据结构中的映射定义了一个接口java.util.Map,此接口主要有四个常用的实现类,分别是HashMap.Hashtable.LinkedHashMap和TreeMap,类继承关系如下图 ...
- 容器HashMap原理(学习)
一.概述 基于哈希表的 Map 接口的非同步实现,允许使用 null 值和 null 键,不保证映射的顺序 二.数据结构 HashMap实际上是一个“链表散列”的数据结构,即数组和链表的结合体:Has ...
随机推荐
- tomcat solr服务无法搜索中文
把tomcat的配置文件修改一下就好了, vi server.xml <Connector port="8080" protocol="HTTP/1.1" ...
- 修改centos7容器的时间和宿主机时间一致
一.问题 centos7系统容器时间与宿主机系统时间不一致,就进去查看一番,发现时区和宿主机上的时间不一致,下面就来解决一下 二.现象 1.查看centos宿主机的时间 输入如下命令查看 # date ...
- leetcode-简单-栈-逆波兰表达式
根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话 ...
- EF CORE中复杂类型的映射
实体映射时,遇到复杂类型,可选择下述方法处理: NotMapped,跳过映射 在复杂类型上声明 [Owned],但仅限该复杂类型是全部由简单值类型组成的 自定义序列化方法 示例: IPInfo使用 ...
- vue中允许你继续使用swiper的组件 vue-awesome-swiper---切图网
swiper是一个在切图中好用到不行的图片轮播插件,包括3d轮播.h5滑屏等复杂应用都不在话下,到了vue项目一切逻辑完全颠覆了,没有获取dom的概念,还好有 vue-awesome-swiper组件 ...
- java 关于xlsx(xls) 和 csv 文件的数据解析
1.适用于xlsx 和 xls <!--xlsx和xls文件pom依赖--> <dependency> <groupId>org.apache.poi</g ...
- Linux系统的安装和常用命令
(1)切换到目录 /usr/bin: (2)查看目录/usr/local 下所有的文件: (3)进入/usr 目录,创建一个名为 test 的目录,并查看有多少目录存在: (4)在/usr 下新建目录 ...
- go 面向对象
结构体 创建结构体变量和访问结构体字段 package main import "fmt" //创建结构体变量和访问结构体字段 type Person struct { Name ...
- webstorm 添加代码模板
file>setting>Live Templates>选择文件类型
- h5 中修改input中 placeholder的颜色
input::-webkit-input-placeholder{ color:blue; } input::-moz-placeholder{ /* Mozilla Firefox 19+ */ c ...