ES6中Map的底層原理是什么?可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
ES6的Map的鍵可以是任意的數(shù)據(jù)結(jié)構(gòu),并且不重復(fù)。
Map利用鏈表,hash的思想來實現(xiàn)。
首先,Map可以實現(xiàn)刪除,而且刪除的數(shù)據(jù)可以是中間的值。而鏈表的優(yōu)勢就是在中間的任意位置添加,刪除元素都非???,不需要移動其他元素,直接改變指針的指向就可以。
。
而在存儲數(shù)據(jù)很多的情況下,會導(dǎo)致鏈條過長,導(dǎo)致查找效率慢,所以我們可以創(chuàng)建一個桶(存儲對象的容器),根據(jù)hash(把散列的值通過算法變成固定的某值)來平局分配數(shù)據(jù),防止鏈條過長。
如下圖:桶里面有3個位置,每一個位置都是一個對象,通過next屬性指向下一個對象來把沒有關(guān)聯(lián)的對象聯(lián)到一起。
把Map屬性值和屬性名都存到對象的值里。
簡單模擬Map,代碼如下:
function Mymap() { //構(gòu)造函數(shù) this.init(); } //初始化函數(shù),創(chuàng)建桶(數(shù)組),每個位置都是一個對象,每個對象的屬性上設(shè)置next屬性,并且初始化為null。 Mymap.prototype.init = function () { this.tong = new Array(8); for (var i = 0; i < 8; i++) { this.tong[i] = new Object(); this.tong[i].next = null; } }; //添加數(shù)據(jù)。 Mymap.prototype.set = function (key, value) { var index = this.hash(key); //獲取到當(dāng)前設(shè)置的key設(shè)置到那個位置上 var TempBucket = this.tong[index]; //獲取當(dāng)前位置的對象 while (TempBucket.next) { //遍歷如果當(dāng)前對象鏈接的下一個不為空 if (TempBucket.next.key == key) { //如果要設(shè)置的屬性已經(jīng)存在,覆蓋其值。 TempBucket.next.value = value; return; //return ,不在繼續(xù)遍歷 } else { TempBucket = TempBucket.next; //把指針指向下一個對象。 } } TempBucket.next = { //對象的next是null ,添加對象。 key: key, value: value, next: null } }; //查詢數(shù)據(jù) Mymap.prototype.get = function (key) { var index = this.hash(key); var TempBucket = this.tong[index]; while(TempBucket){ if(TempBucket.key == key){ return TempBucket.value; }else{ TempBucket = TempBucket.next; } } return undefined; } //刪除數(shù)據(jù) Mymap.prototype.delete = function(key){ var index = this.hash(key); var TempBucket = this.tong[index]; while(TempBucket){ if(TempBucket.next.key == key){ TempBucket.next = TempBucket.next.next; return true; }else{ TempBucket = TempBucket.next; } } } //看當(dāng)前屬性是否存在 Mymap.prototype.has = function(key){ var index = this.hash(key); var TempBucket = this.tong[index]; while(TempBucket){ if(TempBucket.key == key){ return true; }else{ TempBucket = TempBucket.next; } } return false; } //清空這個map Mymap.prototype.clear = function(){ this.init(); } //使設(shè)置的屬性平均分配到每個位置上,使得不會某個鏈條過長。 Mymap.prototype.hash = function (key) { var index = 0; if (typeof key == "string") { for (var i = 0; i < 3; i++) { index = index + isNaN(key.charCodeAt(i)) ? 0 : key.charCodeAt(i); } } else if (typeof key == 'object') { index = 0; } else if (typeof key == 'number') { index = isNaN(key) ? 7 : key; } else { index = 1; } return index % 8; } var map = new Mymap(); //使用構(gòu)造函數(shù)的方式實例化map map.set('name','zwq'); map.get('name'); map.has('name);
看完上述內(nèi)容,你們對ES6中Map的底層原理有進一步的了解嗎?如果還想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道,感謝各位的閱讀。
文章題目:ES6中Map的底層原理是什么-創(chuàng)新互聯(lián)
文章起源:http://chinadenli.net/article44/dejjee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、營銷型網(wǎng)站建設(shè)、ChatGPT、網(wǎng)站內(nèi)鏈、Google、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容