自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

區(qū)塊鏈前置知識(shí)之Hash (一)

區(qū)塊鏈
我們定義這樣一個(gè)場(chǎng)景,約定任意正整數(shù),要存放在長(zhǎng)度為 6 的數(shù)組中,那么此時(shí),我們可以利用 hash 的思想設(shè)計(jì)什么樣的方案來(lái)做到這個(gè)事情呢?

定義

hash 是一種把任意長(zhǎng)度輸入變換成固定長(zhǎng)度輸出的一種算法。

假設(shè)我們已經(jīng)定義了一個(gè) hash 函數(shù)名為 H,輸入內(nèi)容為 message,輸出內(nèi)容為 x,那么就有如下公式。

H(message) = x

這是一個(gè)壓縮的過(guò)程,通常情況下,我們會(huì)把輸出值稱之為 hash 值。

接下來(lái)通過(guò)一個(gè)具體的案例來(lái)了解 hash 的過(guò)程。

我們定義這樣一個(gè)場(chǎng)景,約定任意正整數(shù),要存放在長(zhǎng)度為 6 的數(shù)組中,那么此時(shí),我們可以利用 hash 的思想設(shè)計(jì)什么樣的方案來(lái)做到這個(gè)事情呢?

數(shù)組的具體位置我們可以用下標(biāo)來(lái)表示 0, 1, 2, 3, 4, 5。想要將任意正整數(shù)放入到數(shù)組中,那么我們只需要設(shè)計(jì)一個(gè)函數(shù),輸入值為任意正整數(shù),輸出值為該數(shù)組下標(biāo)中的任意一個(gè)即可,得到了輸出值,我們就相當(dāng)于知道應(yīng)該把輸入值放到數(shù)組中的某個(gè)位置了。

圖片

我們可以使用求余法來(lái)定義這個(gè) hash 函數(shù)。

function suplus(number) {
return number % 6
}

于是,隨便取幾個(gè)數(shù),得到 hash 值之后就能存入數(shù)組對(duì)應(yīng)的位置。

// 輸入值:61
suplus(61) = 1

圖片

// 輸入值:101
suplus(101) = 5

圖片

此時(shí)的哈希值表示的是數(shù)組的下標(biāo),因此在很多應(yīng)用場(chǎng)景,輸出結(jié)果哈希值也被稱為哈希地址。

哈希碰撞

在上面的例子中,輸入值的范圍一定大于輸出值的范圍,這是 hash 的重要特性之一。因此在某些情況下,不同的輸入會(huì)得到相同的輸出結(jié)果。

// 不同的輸入,得到了相同的輸出,哈希地址相同
suplus(7) = 1
suplus(61) = 1

此時(shí)哈希地址相同,按照規(guī)則,我們不得不把不同的值,存入相同的位置,這種情況就被稱之為哈希碰撞(collision)。

解決哈希碰撞的方法很多,這里介紹一個(gè)比較常見(jiàn)的方法:以數(shù)組的每個(gè)地址為根節(jié)點(diǎn),構(gòu)建一個(gè)新的鏈表。

例如當(dāng)輸入數(shù)字分別為 7, 61 時(shí)。

圖片

但是當(dāng)數(shù)據(jù)量龐大時(shí),鏈表的查詢速度比較低效,因此我們?cè)趯?shí)踐中,會(huì)將鏈表替換成紅黑樹等操作效率更高的數(shù)據(jù)結(jié)構(gòu)。

當(dāng)然,最理想的情況是輸出范圍足夠廣,不出現(xiàn) hash 碰撞。因此我們實(shí)踐中使用的 hash 函數(shù),輸出值的范圍都非常龐大,例如早期用得比較多的 md5,現(xiàn)在使用比較多的sha256:比特幣中使用的哈希算法。但是由于輸入值范圍一定大輸出值范圍,因此理論上哈希碰撞一定會(huì)存在。

現(xiàn)在 md5 已經(jīng)可以人為制造 hash 碰撞,因此實(shí)用性大大降低。

本文轉(zhuǎn)載自微信公眾號(hào)「這波能反殺」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系這波能反殺公眾號(hào)。

責(zé)任編輯:姜華 來(lái)源: 這波能反殺
相關(guān)推薦

2021-04-09 06:25:41

區(qū)塊鏈區(qū)塊鏈技術(shù)

2020-02-10 11:32:11

區(qū)塊鏈blockchain智能合約

2021-02-02 10:40:10

區(qū)塊鏈版權(quán)保護(hù)技術(shù)

2018-10-23 10:55:07

2019-11-22 11:10:26

區(qū)塊鏈技術(shù)

2022-08-08 11:53:02

區(qū)塊鏈CIO

2019-06-24 16:30:33

區(qū)塊鏈零知識(shí)證明比特幣

2021-04-18 06:58:35

區(qū)塊鏈賬本結(jié)構(gòu)

2018-03-07 14:06:23

區(qū)塊鏈數(shù)字貨幣比特幣

2018-03-30 10:10:11

區(qū)塊鏈數(shù)字貨幣記賬模式

2018-06-14 11:02:37

區(qū)塊鏈支付寶去中心化

2021-05-19 10:37:16

WebFlux 前置工具

2019-12-10 10:49:40

區(qū)塊鏈幣天銷毀比特幣

2023-05-30 00:07:33

區(qū)塊鏈數(shù)據(jù)結(jié)構(gòu)

2021-11-12 15:52:16

區(qū)塊鏈開(kāi)發(fā)技術(shù)

2018-06-25 10:25:26

區(qū)塊鏈跨鏈協(xié)議

2018-08-19 11:00:05

2021-06-01 10:41:11

WebFlux 數(shù)據(jù)Backpressur

2022-10-26 08:42:28

2018-03-05 17:27:34

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)