炸窝哈希值的原理

package asdfg;

import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
public class aaa {

public static void main(String[] args) {/*** 小提示:* 1.对于所有没有索引的方法,我们都不能使用for循环进行遍历* 2.提到接口,我们就应该想到他下面有多少个实现类,并且实现类的方法是怎样使用的* 3.哈希表结构的速度是非常快的* 4.哈希表的顺序是无序的* 5.可以通过重写的方法使哈希值的值相等* * * Set接口简介:* 1.Java.util.set接口和Java.util.list接口同样继承来自collection接口,与collection接口中的方法基本上是一样的,* 并没有对collectIon接口进行功能上的扩充,只是比collectIon接口在形式上更加严格,与lIst接口不同的是,Set接口中的元素* 是无序的,并且都会以某种规则保证存入的元素不出现重复* 2.Set接口的两个集合:Hashset集合和HashmAP集合* * 小问题:* 1.Hashset是根据什么来确定元素在集合中的存储位置的?具有什么功能?* 解释:是根据对象的哈希值来确定元素在结合中的存储位置,具有良好的存储和查找性能,* 2.Hashset是如何保证元素在集合当中的唯一性的?* 解释:保障元素唯一性的方式依赖于Hashcode方法与EQuals方法*//** Set接口的特点:* 1.不允许存储重复元素* 2.没有索引,没有带索引的方法也不能使用普通for循环进行遍历;* * java.util.HashSet集合 implements(实现)set接口;* HshSet方法的特点:* 1.不允许存储重复元素* 2.没有索引,没有带索引的方法也不能使用普通for循环进行遍历* 3.是一个无序的集合,存储元素和起初元素的分析有可能不一致* 4.底层是一个哈希表结构,(查询的速度是相当迅速的)* *///创建一个HashSet集合Set<Integer> set= new HashSet<>();//添加元素使用add方法set.add(1);set.add(3);set.add(2);set.add(1);		//1.使用迭代器进行遍历set集合Iterator<Integer> it=set.iterator();//判断是否有下一个while(it.hasNext()){//如果有的话,将下一个的值进行返回然后进行输出Integer n=it.next();System.out.println(n);}//2.使用增强for遍历for集合System.out.println("+++++++++++++++++++++");for(Integer i :set){System.out.println(i);}//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++/*** HashSet集合存储数据的结构使用的是哈希表,下面我们进行了解哈希值是怎么一回事* 哈希值:是一个十进制的整数 由系统随机给值,是一个模拟地址,不是真实存在的,也就是逻辑上的地址值,注意:是逻辑地址值,而不是物理地址* * 如何获取对象的哈希值?* 使用Object类当中的方法来获取对象的哈希值* 该方法位于java.long.Object类中的hashcode()方法 其作用是返回该对象的哈希值码* * *//*** hashcode方法的源码:*  public native int hashCode();*  native代表该方法调用的是本地操作系统的方法*  *  *///因为person extends Object,所以可以使用其中的hashCode方法person p1=new person();int h1=p1.hashCode();//对象的哈希值System.out.println(h1);//31168322System.out.println(p1);//asdfg.person@1db9742就是上面逻辑地址当中的十六进制的表示//在创建另外的一个对象person p2=new person();int h2=p2.hashCode();//对象的哈希值System.out.println(h2);//17225372System.out.println(p2);//asdfg.person@106d69c就是上面逻辑地址当中的十六进制的表示//String 的哈希值String s1=new String("abc");String s2=new String("abc");System.out.println(s1.hashCode());//96354System.out.println(s2.hashCode());//96354//字符串重写之后的哈希值是相同的//哈希值的改变是可以通过方法的程序进行的,如果哈希值不被重写,就是由系统随机给出的,/*** 什么是哈希表?* 在JDK1.8之前,哈希表底层采用数组+链表结构,及使用链表处理冲突,这里的冲突是指当一个哈希值对应多个数据的时候,不行,* 但是它位于一个桶中的元素较多及hash值相等的元素较多时,通过key查找效率较低,而JDK1.8中,哈希值存储结构采用数据+链表+红黑树实现,* 超过8(阀值)将链表转换为红黑树,这样大大减少了查找时间,简单来说,链表是由数组+链表+红黑树实现的,* * 哈希表的结构特点:* 查询速度快* * 哈希表结构当中数组的个数一开始是16个块,从0开始,初始容量是16个* * 数组结构:将相同哈希值的元素分为一组* 链表/红黑树:将哈希值相同的元素放到一起或者说是连接到一起* */
}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/444122.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

剑指offer:45-48记录

输入一个正整数数组&#xff0c;把数组里所有数字拼接起来排成一个数&#xff0c;打印能拼接出的所有数字中最小的一个。 示例 1: 输入: [10,2] 输出: "102" 示例 2: 输入: [3,30,34,5,9] 输出: "3033459" 提示: 0 < nums.length < 100 说明:…

炸窝(可变函数)

可变函数源码理解&#xff1a;学生角度&#xff0c;更易操作 public static void main(String[] args) {/*int cadd(10,29);System.out.println(c);*///此时可以随意的进行数据的传递add(20,30,40);//[I1db9742:解释&#xff0c;中括号代表是一个数组&#xff0c;为一个地址值…

剑指offer:50-53记录

在字符串 s 中找出第一个只出现一次的字符。如果没有&#xff0c;返回一个单空格。 示例: s "abaccdeff" 返回 "b" s "" 返回 " " 限制&#xff1a; 0 < s 的长度 < 50000 思路&#xff1a;map记录次数&#xff0c;再…

Eclipse安装插件的几种方式

前段时间Google转向了IDEA&#xff0c;貌似有些动摇了Eclipse作为Java领域IDE龙头老大的位置&#xff0c;为此引起了Eclipse粉丝和IDEA粉丝的集体骂战。类似这种骂战向来都不绝于耳&#xff0c;貌似程序员的都比较多&#xff0c;可能大家都是搞技术出身&#xff0c;都很自信。其…

炸窝(Collections当中的addAll方法)

public class aaa { public static void main(String[] args) {/** java.util.Collections是集合工具类&#xff0c;用来对集合进行操作&#xff0c;* * 集合Collections当中的两个方法&#xff1a;* 1.addAll方法&#xff1a;因为是静态方法&#xff0c;嗯所以可以.直接吹风机…

剑指offer:55-58记录

输入一棵二叉树的根节点&#xff0c;求该树的深度。从根节点到叶节点依次经过的节点&#xff08;含根、叶节点&#xff09;形成树的一条路径&#xff0c;最长路径的长度为树的深度。 例如&#xff1a; 给定二叉树 [3,9,20,null,null,15,7]&#xff0c; 3 / \ 9 20 …

Map集合知识点(炸窝)

/** * 简单的介绍一下我们接下来准备学习的集合MAP集合 * * Map集合的简单概述&#xff1a; * 其中的健是不能进行重复的&#xff0c;而且每一健只能映射一个值&#xff0c;简单的说就是K与V是一一对应的&#xff0c;不能有其他的关系&#xff0c; * 但是我们注意到value值是可…

剑指offer:63-66记录

假设把某股票的价格按照时间先后顺序存储在数组中&#xff0c;请问买卖该股票一次可能获得的最大利润是多少&#xff1f; 示例 1: 输入: [7,1,5,3,6,4] 输出: 5 解释: 在第 2 天&#xff08;股票价格 1&#xff09;的时候买入&#xff0c;在第 5 天&#xff08;股票价格 6&a…

【大总结3】leetcode解题总览(算法、剑指offer、SQL、多线程、shell)

3/22更新 剑指offer 题目链接 建议大部分题都会做&#xff0c;都能比较快速且准确的写出来。关于做题方式&#xff0c;我的建议是&#xff1a;一道一道刷即可&#xff0c;因为难度一般&#xff0c;不用系统的学习什么知识&#xff0c;遇到实在不会的就跳过即可。 我这里写了…

逆序存储【数据结构】

C语言中malloc是动态内存分配函数。 函数原型&#xff1a;void malloc(unsigned int num_bytes); 参数&#xff1a;num_bytes 是无符号整型&#xff0c;用于表示分配的字节数。 返回值&#xff1a;如果分配成功则返回指向被分配内存的指针(此存储区中的初始值不确定)&#xff0…

为什么 main 方法是 public static void ?

main 方法是我们学习Java编程语言时知道的第一个方法&#xff0c;你是否曾经想过为什么 main 方法是 public、static、void 的。当然&#xff0c;很多人首先学的是C和C&#xff0c;但是在Java中main方法与前者有些细微的不同&#xff0c;它不会返回任何值&#xff0c;为什么 ma…

返回地址【数据结构】

小问题&#xff1f; 1.我们是如何根据地址值来找到我们对应的数据的&#xff1f; 详细陈述一下&#xff1a;当我们开辟一个整数类型&#xff0c;取名为a&#xff0c;假设地址空间是从数值为2000进行存储&#xff0c;并且我们假设整形占用4个字节&#xff0c;那么我们在内存中需…

【超级详细的小白教程】Hexo 搭建自己的博客

– 前言 这是一篇有关如何使用 Github Pages 和 Hexo 搭建属于自己独立博客的详尽教程&#xff0c;本人是软件工程专业本科生&#xff0c;目前只学习了C和C编程语言&#xff0c;对网站开发的有关知识几乎为零&#xff0c;这也是我搭建好自己的博客之后写的第一篇博客&#xff…

面向对象思想精华总结

一、三大特性 封装继承多态 二、类图 泛化关系 (Generalization)实现关系 (Realization)聚合关系 (Aggregation)组合关系 (Composition)关联关系 (Association)依赖关系 (Dependency) 三、设计原则 S.O.L.I.D其他常见原则 参考资料 一、三大特性 封装 利用抽象数据类型将数据…

数组名与指向数组的指针之间的联系与区别【数据结构】

我们遇到一个非常棘手的问题&#xff0c;这个问题就是&#xff0c;对于一堆数据来说&#xff0c;我们进行存储&#xff0c;放到一个指定的仓库当中&#xff0c;先前我们使用数组加加标的形式进行访问仓库当中的元素位置&#xff0c;但是呢&#xff0c;现在我们使用的是一个指针…

Struts2的action中处理JSONP方式提交的中文乱码问题:

昨天在做公司网站的时候出现了一个中文乱码问题&#xff0c;让我郁闷了一晚上和一上午&#xff0c;最后在网友的提示下&#xff0c;我终于解决了&#xff0c;现在写出来供后来的兄弟们参考&#xff1a; 1.问题是这样的&#xff0c;就是客户端是以JSONP的方式提交的数据&#x…

leetcode509. 斐波那契数(矩阵快速幂)

斐波那契数&#xff0c;通常用 F(n) 表示&#xff0c;形成的序列称为斐波那契数列。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0, F(1) 1 F(N) F(N - 1) F(N - 2), 其中 N > 1. 给定 N&#xff0c;计算 F(N)。…

insert函数的修改,

我们来看一下图片当中的第2个圆圈&#xff0c;为什么使用size来相加呢&#xff1f;我们知道一开始我们定义的初始空间为init_size;我们想一下啊&#xff0c;如果是第1次进行空间的增加&#xff0c;那么我们使用InIt来进行相加是可以的&#xff0c;但是当第2次想加我们再想开辟空…

leetcode520. py解字符串真是太残暴了

给定一个单词&#xff0c;你需要判断单词的大写使用是否正确。 我们定义&#xff0c;在以下情况时&#xff0c;单词的大写用法是正确的&#xff1a; 全部字母都是大写&#xff0c;比如"USA"。 单词中所有字母都不是大写&#xff0c;比如"leetcode"。 如果…

【数据结构】线性表大咖

循环链表的介绍 概念&#xff1a;链表的最后一个节点的指针&#xff0c;由原来的 空指针变成指向第1个节点的链表。 类比&#xff1a;我们进行串珠子的操作&#xff0c;将首尾通过线进行连接&#xff0c;同样我们的链表就是通过指针指向的方式进行连接&#xff0c;使其成为一…