《數(shù)據(jù)結(jié)構(gòu)與算法之美》17——哈希算法(一)基本概念與應(yīng)用

什么是哈希算法

將任意長(zhǎng)度的二進(jìn)制值串映射為固定長(zhǎng)度的二進(jìn)制值串,這個(gè)映射的規(guī)則就是哈希算法。而通過原始數(shù)據(jù)映射之后得到的二進(jìn)制值串就是哈希值忘晤。

一個(gè)優(yōu)秀的哈希算法要滿足幾點(diǎn)要求:

  1. 從哈希值不能反向推導(dǎo)出原始數(shù)據(jù)(所以哈希算法也叫意向哈希算法)吴汪;
  2. 對(duì)輸入數(shù)據(jù)非常敏感寄摆,哪怕原始數(shù)據(jù)只修改了一個(gè)Bit,最后得到的哈希值也大不相同懦窘;
  3. 散列沖突的概率要很小前翎,對(duì)于不同的原始數(shù)據(jù),哈希值相同的概率非常谐┩俊港华;
  4. 哈希算法的執(zhí)行效率要盡量高效,針對(duì)較長(zhǎng)的文本毅戈,也能快速地計(jì)算出哈希值苹丸。

哈希算法的應(yīng)用

哈希算法的應(yīng)用有很多,常見的有:安全加密苇经、唯一標(biāo)識(shí)赘理、數(shù)據(jù)較驗(yàn)、散列函數(shù)扇单、負(fù)載均衡商模、數(shù)據(jù)分片、分布式存儲(chǔ)蜘澜。

應(yīng)用一:安全加密

說到哈希算法的應(yīng)用施流,最先想到的就是安全加密。最常用的哈希算法是MD5和SHA鄙信。

沒有絕對(duì)安全的加密瞪醋。越復(fù)雜、越難破解的加密算法装诡,需要的計(jì)算時(shí)間也越長(zhǎng)银受。

應(yīng)用二:唯一標(biāo)識(shí)

通過哈希算法對(duì)文件進(jìn)行哈希計(jì)算,得到的哈希值作為文件的唯一標(biāo)識(shí)鸦采。通過這個(gè)唯一標(biāo)識(shí)可以在數(shù)據(jù)庫中快速找到對(duì)應(yīng)的文件宾巍。

網(wǎng)盤的秒傳功能就是基于這個(gè)方法實(shí)現(xiàn)的。在上傳之前渔伯,先計(jì)算文件的哈希值顶霞,再到數(shù)據(jù)庫中查找,如果找到锣吼,就直接提示上傳成功选浑。

應(yīng)用三:數(shù)據(jù)校驗(yàn)

相信大家都用過BT下載軟件吧蓝厌?我們知道,BT下載的原理是基于P2P協(xié)議的鲜侥。從多個(gè)機(jī)器上并行下載一個(gè)2GB的電影褂始,這個(gè)電影文件可能會(huì)被分割成很多個(gè)文件塊(比如分成1000塊,每塊大約2MB)描函。等所有文件塊都下載完成之后崎苗,再組裝成一個(gè)完整的電影文件。

具體的BT協(xié)議很復(fù)雜舀寓,校驗(yàn)方法也有很多胆数,這里說其中一種思路。

通過哈希算法互墓,對(duì)1000個(gè)文件塊分別取哈希值必尼,并且保存在種子文件中。當(dāng)文件塊下載完成后篡撵,通過相同的哈希算法判莉,對(duì)下載好的文件塊逐一對(duì)比。如果不同育谬,說明這個(gè)文件塊不完成或者被篡改了券盅,需要再生產(chǎn)從其他宿主機(jī)器上下載這個(gè)文件塊。

應(yīng)用四:散列函數(shù)

散列函數(shù)是哈希算法的一種應(yīng)用膛檀,更加看重的是散列的平均性和哈希算法的執(zhí)行效率锰镀。

課后思考

現(xiàn)在,區(qū)塊鏈?zhǔn)且粋€(gè)很火的領(lǐng)域咖刃,它被很多人神秘化泳炉,不過其底層的實(shí)現(xiàn)原理并不復(fù)雜。其中嚎杨,哈希算法就是它的一個(gè)非常重要的理論基礎(chǔ)花鹅。你能講一講區(qū)塊鏈?zhǔn)褂玫氖悄姆N哈希算法嗎?是為了解決什么問題而使用的呢枫浙?

  • SHA 256:產(chǎn)生一個(gè)256位哈希刨肃。這是目前比特幣正在使用的。
  • Keccak-256:產(chǎn)生256位哈希自脯,目前由Ethereum使用。
  • CryptoNight:Monero使用的哈希函數(shù)斤富。

保證每個(gè)區(qū)塊是唯一標(biāo)識(shí)的膏潮、不可逆、無沖突满力。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末焕参,一起剝皮案震驚了整個(gè)濱河市轻纪,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌叠纷,老刑警劉巖刻帚,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異涩嚣,居然都是意外死亡崇众,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門航厚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來顷歌,“玉大人,你說我怎么就攤上這事幔睬∶袖觯” “怎么了?”我有些...
    開封第一講書人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵麻顶,是天一觀的道長(zhǎng)赦抖。 經(jīng)常有香客問我,道長(zhǎng)辅肾,這世上最難降的妖魔是什么队萤? 我笑而不...
    開封第一講書人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮宛瞄,結(jié)果婚禮上浮禾,老公的妹妹穿的比我還像新娘。我一直安慰自己份汗,他們只是感情好盈电,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著杯活,像睡著了一般匆帚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上旁钧,一...
    開封第一講書人閱讀 51,604評(píng)論 1 305
  • 那天吸重,我揣著相機(jī)與錄音,去河邊找鬼歪今。 笑死嚎幸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的寄猩。 我是一名探鬼主播嫉晶,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了替废?” 一聲冷哼從身側(cè)響起箍铭,我...
    開封第一講書人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎椎镣,沒想到半個(gè)月后诈火,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡状答,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年冷守,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剪况。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡教沾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出译断,到底是詐尸還是另有隱情授翻,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布孙咪,位于F島的核電站堪唐,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏翎蹈。R本人自食惡果不足惜淮菠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望荤堪。 院中可真熱鬧合陵,春花似錦、人聲如沸澄阳。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽碎赢。三九已至低剔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間肮塞,已是汗流浹背襟齿。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枕赵,地道東北人猜欺。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像拷窜,于是被迫代替她去往敵國(guó)和親开皿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子钓试,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355