什么是Hash哈希(散列表)

Hash哈希,也称散列表,是一种将任意长度输入转化为固定长度输出的算法思想。哈希函数包括直接寻址、数字分析法、平方取中法等,其性质包括不可逆性、冲突可能性等。主要用于文件校验、数字签名和文件压缩等领域。
摘要由CSDN通过智能技术生成

什么是Hash哈希(散列表)

相信学计算机的各位都绝对听过Hash哈希(散列表),有些人认为Hash是一种算法,有人认为它是一种数据结构,其实这些说法都不算太准确.其实hash是一类算法的集合,或者说是一种算法思想

定义

  • Baidu:Hash,一般翻译做散列、杂凑,或音译为哈希,是把任意长度的输入(又叫做预映射pre-image)通过散列算法变换成固定长度的输出,该输出就是散列值。

  • Wikipedia:A hash function is any function that can be used to map data of arbitrary size to fixed-size values. (一个哈希函数就是一个能把任意长度的数据映射到固定长度的值的函数)

    可以看出百度百科和维基的定义十分相似,提炼出来就是hash就是把任意长度的数据变成固定长度的数据.而且维基百科的定义还说了,只要一个函数能做这件事,它就是hash哈希函数. 这就能充分说明上文的观点.在这里插入图片描述

哈希函数

一个符合hash哈希思想的函数.常见的hash函数有:

  • 直接寻址:取关键字或关键字的某个线性函数值为散列地址
  • 数字分析法:分析一组数据找出数字的规律,尽可能利用这些数据来构造冲突几率较低的散列地址。
  • 平方取中法:取关键字平方后的中间几位作为散列地址。

性质

  1. Hash值相同,两者的原始输入不一定相同
  2. Hash值不同,两者的原始输入一定不同,因为会产生’冲突’
  3. Hash算法通常是把长的输入变成短的输出
  4. Hash算法是不可逆的,也就是说你可以用原始输入通过Hash函数获得Hash值,但是你不能通过Hash值来获得原始输入

作用

  1. 文件校验
  2. 数字签名
  3. 文件压缩
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值