JavaScript Map實(shí)現(xiàn)原理與底層結(jié)構(gòu)詳解
前言
比如,有一天,我們?nèi)ベ?gòu)物店買(mǎi)了一件新的、不熟悉的商品。
張三:這個(gè)商品多少錢(qián)
收銀員:(在鍵盤(pán)上噼啪作響。。。)
收銀員:88元,給你湊個(gè)整。
(滴。。。付款成功)
成功支付90元。
hash表
收銀員如何在數(shù)千件商品中如此迅速地找到這件商品的價(jià)格。
有人說(shuō)可以遍歷暴力查詢(xún),總能找到項(xiàng)目。
如果有一百萬(wàn)種產(chǎn)品,需要多少時(shí)間?雖然始終可以從頭到尾查詢(xún),但我們追求更好的性能,這就是我們的哈希表存儲(chǔ)。

我們需要做的就是將商品轉(zhuǎn)化為下標(biāo)形式的數(shù)字,并對(duì)應(yīng)數(shù)組的下標(biāo),這樣下次遇到這個(gè)商品,就可以直接根據(jù)下標(biāo)獲取我們需要的信息了。
就像我們有一根香蕉?? banana(香蕉)
我們想一個(gè)辦法把它變成一個(gè)數(shù)字:
function getHash(str) {
let _hash = 0;
for (let i = 0; i < str.length; i++) {
const charCode = str.charCodeAt(i);
_hash += charCode;
}
return _hash;
}
console.log(getHash('banana')) //609
這里我們計(jì)算出它對(duì)應(yīng)的數(shù)字是609。
這里我們只是添加了字母對(duì)應(yīng)的ascii下標(biāo)。僅供參考和學(xué)習(xí)。一個(gè)好的哈希算法應(yīng)該盡量避免下標(biāo)過(guò)多和下標(biāo)分散過(guò)大,還要處理和解決哈希沖突。
所以我們可以將數(shù)組下標(biāo)到位置 609 并添加價(jià)格,arr[609] = 66,這里設(shè)置66元。
下次查詢(xún)香蕉的價(jià)格,還是可以通過(guò) getHash 算出609,直接取數(shù)組的下標(biāo)就可以得到我們的價(jià)格,只需要O(1)的時(shí)間。
實(shí)現(xiàn) get 功能
function get(key){
let _hash = getHash(key);
//這里的 arr 代表我們存儲(chǔ)數(shù)據(jù)的數(shù)組
if(!this.arr[_hash]){
//如果沒(méi)查到數(shù)據(jù),返回undefined
return undefined;
}
return this.arr[_hash];
}
實(shí)現(xiàn) set 功能
function set(key,value){
let _hash = getHash(key);
//這里的 arr 代表我們存儲(chǔ)數(shù)據(jù)的數(shù)組
this.arr[_hash] = value;
}
做個(gè)測(cè)試
class MyHash {
constructor(){
this.arr = [];
}
get(key) {
let _hash = getHash(key);
//這里的 arr 代表我們存儲(chǔ)數(shù)據(jù)的數(shù)組
if (!this.arr[_hash]) {
//如果沒(méi)查到數(shù)據(jù),返回undefined
return undefined;
}
return this.arr[_hash];
}
set(key, value) {
let _hash = getHash(key);
//這里的 arr 代表我們存儲(chǔ)數(shù)據(jù)的數(shù)組
this.arr[_hash] = value;
}
}
let myhash = new MyHash();
myhash.set('banana', '88')
console.log(myhash.get('banana'))
到此這篇關(guān)于JavaScript Map實(shí)現(xiàn)原理與底層結(jié)構(gòu)詳解的文章就介紹到這了,更多相關(guān)JS Map內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spirngmvc js傳遞復(fù)雜json參數(shù)到controller的實(shí)例
下面小編就為大家分享一篇spirngmvc js傳遞復(fù)雜json參數(shù)到controller的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片滾動(dòng)附源碼下載
JavaScript實(shí)現(xiàn)簡(jiǎn)單圖片滾動(dòng),9張圖告訴你,C羅欲哭無(wú)淚,另附源碼下載,方便學(xué)習(xí)2014-06-06
詳解用webpack把我們的業(yè)務(wù)模塊分開(kāi)打包的方法
本篇文章主要介紹了用webpack把我們的業(yè)務(wù)模塊分開(kāi)打包的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
JavaScript通過(guò)attachEvent和detachEvent方法處理帶參數(shù)的函數(shù)
通過(guò) attachEvent 和 detachEvent 方法處理帶參數(shù)的函數(shù)(示例代碼)2010-03-03
JS+CSS實(shí)現(xiàn)經(jīng)典的左側(cè)豎向滑動(dòng)菜單效果
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)經(jīng)典的左側(cè)豎向滑動(dòng)菜單效果,涉及JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
通過(guò)JS動(dòng)態(tài)創(chuàng)建一個(gè)html DOM元素并顯示
需要通過(guò)點(diǎn)擊某個(gè)元素后, 動(dòng)態(tài)創(chuàng)建一個(gè)DOM元素并顯示,因此寫(xiě)了一些相關(guān)的js函數(shù),在此記錄下2014-10-10
JavaScript中常用的五種數(shù)字千分位格式化方法
數(shù)字格式化是開(kāi)發(fā)中經(jīng)常遇到的任務(wù),特別是在需要為數(shù)字添加千分位符或控制小數(shù)位數(shù)時(shí),以下是幾種常用的數(shù)字格式化方法,每種方法有其優(yōu)缺點(diǎn),適用于不同的需求場(chǎng)景,感興趣的小伙伴跟著小編一起來(lái)看看吧2024-12-12
JavaScript仿小米官網(wǎng)注冊(cè)登錄功能的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何通過(guò)JavaScript實(shí)現(xiàn)仿小米官網(wǎng)登錄注冊(cè)完整功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11

