百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

区块链基础-哈希(hash)是啥 哈希运算是区块链发展的里程碑吗

haoteby 2024-11-11 12:45 13 浏览

如果你从事编程,或者对区块链感兴趣,那么哈希这个词肯定经常听到,那么哈希到底是什么,今天就简单聊一聊。

首先我有一个算法,有一个输入和一个输出,换句话说当你输入一个数据,我返回给你一个数据。我们假定一下我的算法是 +1,然后算法的输入和输出都是数字,当你输入一个数字时,我返回给你一个数字,那么根据我这个算法,我们就知道,当你输入一个数字时,输出的一定是另外一个数字,因为我输出的数字是在你的基础上加一,而且我们也知道没有最大的数字(不考虑计算机能使用的最大数值),这样就有一个明显的特点:输入的数据不同,输出的数据一定不同。

这只是哈希的一个特点,并且我上面的例子并不是非常确定,首先上面的例子,当我知道输出的数据是什么的时候,我可以推算出输入的数据是什么。这样是非常不安全的,如果哈希算法是这样,那么也就没有用了。那么下一个特点就出来了:根据输出结果,不能计算出输入结果。就是说在上一个特点的基础上,我们不仅让输出的数据唯一,而且输出的数据不能在推算出输入数据。

在我们第一个例子中,我们输出的数字大小是无限的,也就是说,输出的数据的长度不是固定的,而且是根据你输入的数据来改变的。这也不是我们想要的。那么另外一个特点就出来了:输出的数据是固定长度。举个例子,在之前的例子中,我们输入1,输出2,输入10,输出11。在保持新的特点时,就可能是这样,输入1,输出:164728798263,输入2,输出:875730978359。不仅输出的数据不固定了,而且长度也固定了。

不知道根据上面的例子大家有没有发现另外一个特点,当我输入1和输入2时,输出的两个数据差距非常大,不错,这也是一个特点:输入的两个数据差别不大时,输出的数据差距非常大。大家可能会想,那我如果输入两个差距很大的数据,那么输出的差别是不是就很小了?当然不是,这个特点主要是说,无论你输入什么数据,只要是不同的,输出的数据肯定不同,而且差别很大。

不知道大家有没有想过,当我们输出的数据定长,并差距很大,而且根据输入数据唯一时,那么会不会发生碰撞,就是说当我输入两个数据时,有没有可能输出两个相同的数据。从数学上来说,这是一定可能发生的,当我们定长时,那么输出的数据一定是有限的,假如我们输出的数据个数是n,那么当我们输入了n+1次不同的数据时,那么肯定有两个是相同的,这是一定的。但是在现实中这是不可行的,因为如果我们要做n+1次操作的话,如果使用计算机来操作,很有可能是需要几十年甚至几百年的。想一下 ipv6,可以让世界上每一粒沙子都配一个ip,大概就是这个意思了。

怎么样,哈希没有那么难吧,理解起来非常简单,但是实现起来就不简单了,目前有很多的算法:MD4,MD5,SHA 家族等等,都是为了实现哈希,但是 MD5 已经完成碰撞了。好在现在我们不需要实现这个算法了,只需要知道如何使用就可以了,如果想要认识区块链,那么哈希一定是第一步。

感谢阅读,祝大家生活愉快!

相关推荐

JAVA零基础入门:JDK的概述及安装(jdk完整安装教程)

一.什么是jdkJDK(JavaDevelopmentToolKit)是Java开发工具包,JDK是整个JAVA的核心,包括了Java运行环境(JavaRuntimeEnvirnment),一...

开源、强大的工作流引擎:camunda入门介绍

原创不易,请多多支持!对Java技术感兴趣的童鞋请关注我,后续技术分享更精彩。简介CamundaisaJava-basedframeworksupportingBPMNforwork...

Centos8搭建Java环境(JDK1.8+Nginx+Tomcat9+Redis+Mysql)

一、开篇1.1目的每次换新的服务器,都要找资料配下环境,所以我写这篇文章,重新梳理了一下,方便了自己,希望也能给大家带来一些帮助。安装的软件有:JDK1.8+Nginx+Tomcat9+...

记录一次tomcat的升级过程(tomcat6升级tomcat8)

原因:ApacheTomcat资源管理错误漏洞(CVE-2021-42340)版本:ApacheTomcat/9.0.46,tomcat解决方法:升级tomcat9到最新版本9.0.581.官...

Tomcat10安装与配置图文教程(tomcat安装及配置)

Tomcat10安装与配置图文教程1、百度搜索“tomcat下载”,进入官网下载https://tomcat.apache.org/index.html...

VS2022配置x86/x64调用32位和64位汇编语言动态库环境

配置X86MASM汇编环境1.创建项目打开VS2022创建新项目,新建asm文件(注意要手动修改cpp文件后缀名为asm文件后缀名)。2.设置入口点选择菜单栏中的“调试”-“demo调试属性”-...

ARM版Win10用户狂喜 微软全新补丁让应用不再不兼容

Windows10onARM仅支持模拟32位的X86应用程序,这意味着大多数的桌面应用是无法在这一平台上运行的,这在很大程度上限制该平台的发展。为了解决这一问题,微软在内部开发频道推出可用于AR...

分享收藏的 oracle 11.2.0.4各平台的下载地址

概述oracle11.2.0.4是目前生产环境用的比较多的版本,同时也是很稳定的一个版本。目前官网上已经找不到下载链接了,有粉丝在头条里要求分享一下下载地址。一、各平台下载地址...

Android-x86现已基于5.1.1 Lollipop:支持UEFI和64位内核

采用Linux内核的Android-x86,旨在为PC带来最新的Android移动操作系统体验。而近日,该操作系统已经发布了Android-x865.1的首个候选发布(RC)版本。发行说明中提到:A...

Linux Kernel源码阅读: x86-64 系统调用实现细节(二)

特别说明:该文章前两天发布过,但一直在审核中。看头条网友说字数太多可能一直处于审核中状态,我把该文章拆分成几个章节发布,如影响阅读体验还请见谅。五、系统调用编号...

树莓派4B安装win10后实测,CPU秒杀AMD Athlon64 3200+

在上一篇文章介绍了如何给树莓派4B安装win10系统,这篇就简单对系统进行测试,上一篇文章链接https://www.toutiao.com/i7015518822056886821/因为树莓派是a...

一键离线部署x86、arm64 RabbitMQ,花了2天去验证整理,直接拿去

最近有一个项目,客户是内网网络,只能离线部署,采用的麒麟ARM64服务器系统,不能远程部署,需要提前准备离线部署包让客户IT拷备上去再现场部署,部署时间就只有1天。自家系统采用的vue+springb...

Linux软件包管理(linux系统软件包的安装方法,并简要说明其特点)

Linux系统如果需要安装软件怎么办?如何安装,大概有以下几种方式1.二级制软件包管理(RPM、YUM)...

Tachyum要做全球最强64位处理器:性能比X86强,面积比ARM小

全球半导体芯片研发、生产最强的国家非美国莫属,如果有某家美国公司宣布要开发性能超强的芯片,大家不会意外,但要是一家斯洛伐克初创公司宣布要研发超级芯片呢?Tachyum公司就是这样一家公司,成立于201...

Android L 64位模拟器终于来了:x86独享

GoogleI/O2014大会已经过去了很久,64位的AndroidL依然停留在纸面上,但现在至少可以让开发者们先行品尝品尝了:64位的AndroidL模拟器已经发布。这次公布的模拟器镜像是专...