數(shù)據(jù)結(jié)構(gòu)(八)之字典結(jié)構(gòu)

如需轉(zhuǎn)載, 請咨詢作者, 并且注明出處.
有任何問題, 可以關(guān)注我的微博: coderwhy, 或者添加我的微信: 372623326

數(shù)組-集合-字典是幾乎編程語言都會默認提供的數(shù)據(jù)類型.

在JavaScript中默認提供了數(shù)組, 但沒有提供集合和字典(ES6中增加了), 在上一章節(jié)中, 我們自己通過對象實現(xiàn)了一下集合.

本章, 我們還是基于對象實現(xiàn)一下字典.

一. 認識字典

字典的介紹

  • 生活中的字典
    • 中文字典我們可以根據(jù)拼音去查找漢字, 并且找到漢字對應(yīng)的詞以及解釋.
    • 英文字典也是類似, 根據(jù)英文字母找到對應(yīng)的單詞, 再查看其翻譯和應(yīng)用場景.
    • 很多編程語言中都有字典的概念
  • 字典有什么特點呢?
    • 字典的主要特點是一一對應(yīng)的關(guān)系.
    • 比如保存一個人的信息, 在合適的情況下取出這些信息.
    • 使用數(shù)組的方式: [18, "Coderwhy", 1.88]. 可以通過下標值取出信息.
    • 使用字典的方式: {"age" : 18, "name" : "Coderwhy", "height": 1.88}. 可以通過key取出value
  • 字典的映射關(guān)系:
    • 有些編程語言中稱這種映射關(guān)系為字典, 因為它確實和生活中的字典比較相似. (比如Swift中Dictionary, Python中的dict)
    • 有些編程語言中稱這種映射關(guān)系為Map, 注意Map在這里不要翻譯成地圖, 而是翻譯成映射. (比如Java中就有HashMap&TreeMap等)
  • 字典和數(shù)組:
    • 字典和數(shù)組對比的話, 字典可以非常方便的通過key來搜索對應(yīng)的value, key可以包含特殊含義, 也更容易被人們記住.
  • 字典和對象:
    • 很多編程語言(比如Java)中對字典和對象區(qū)分比較明顯, 對象通常是一種在編譯期就確定下來的結(jié)構(gòu), 不可以動態(tài)的添加或者刪除屬性. 而字典通常會使用類似于哈希表的數(shù)據(jù)結(jié)構(gòu)去實現(xiàn)一種可以動態(tài)的添加數(shù)據(jù)的結(jié)構(gòu).
    • 但是在JavaScript中, 似乎對象本身就是一種字典. 所有在早期的JavaScript中, 沒有字典這種數(shù)據(jù)類型, 因為你完全可以使用對象去代替.
    • 但是這里我們還是按照其他語言經(jīng)常使用字典的方式去封裝一個字典類型, 方便我們按照其他語言的方式去使用字典. (雖然本質(zhì)上它內(nèi)部還是用了一個對象, 后面學(xué)習(xí)完哈希表我會簡單談一下對象和哈希表的關(guān)系)

創(chuàng)建字典類

  • 我們向之前封裝集合一樣, 封裝一個字典的構(gòu)造函數(shù)

    // 創(chuàng)建字典的構(gòu)造函數(shù)
    function Dictionay() {
        // 字典屬性
        this.items = {}
        
        // 字典操作方法
    }
    
  • 代碼解析:

    • 非常簡單, 創(chuàng)建一個Dictionary的構(gòu)造函數(shù), 用于我們字典的封裝.
    • 在字典中, 我們使用了一個items屬性, 該屬性是一個Object對象.
    • 也就是我們的字典是基于Object封裝的, 這個不難理解: 就像我們之前封裝Stack和Queue是基于數(shù)組的一樣.
    • 后面我們在添加字典相關(guān)的操作

二. 操作字典

我們之前封裝的數(shù)據(jù)結(jié)構(gòu), 都有封裝各種操作, 字典也是一樣

常見的操作

  • 字典常見的操作
    • set(key,value):向字典中添加新元素测砂。
    • remove(key):通過使用鍵值來從字典中移除鍵值對應(yīng)的數(shù)據(jù)值。
    • has(key):如果某個鍵值存在于這個字典中百匆,則返回true砌些,反之則返回false
    • get(key):通過鍵值查找特定的數(shù)值并返回加匈。
    • clear():將這個字典中的所有元素全部刪除存璃。
    • size():返回字典所包含元素的數(shù)量。與數(shù)組的length屬性類似雕拼。
    • keys():將字典所包含的所有鍵名以數(shù)組形式返回纵东。
    • values():將字典所包含的所有數(shù)值以數(shù)組形式返回。

操作的實現(xiàn)

  • 我們將這些方法放在一起實現(xiàn)

    // 創(chuàng)建字典的構(gòu)造函數(shù)
    function Dictionay() {
        // 字典屬性
        this.items = {}
    
        // 字典操作方法
        // 在字典中添加鍵值對
        Dictionay.prototype.set = function (key, value) {
            this.items[key] = value
        }
    
        // 判斷字典中是否有某個key
        Dictionay.prototype.has = function (key) {
            return this.items.hasOwnProperty(key)
        }
    
        // 從字典中移除元素
        Dictionay.prototype.remove = function (key) {
            // 1.判斷字典中是否有這個key
            if (!this.has(key)) return false
    
            // 2.從字典中刪除key
            delete this.items[key]
            return true
        }
    
        // 根據(jù)key去獲取value
        Dictionay.prototype.get = function (key) {
            return this.has(key) ? this.items[key] : undefined
        }
    
        // 獲取所有的keys
        Dictionay.prototype.keys = function () {
            return Object.keys(this.items)
        }
    
        // 獲取所有的value
        Dictionay.prototype.values = function () {
            return Object.values(this.items)
        }
    
        // size方法
        Dictionay.prototype.size = function () {
            return this.keys().length
        }
    
        // clear方法
        Dictionay.prototype.clear = function () {
            this.items = {}
        }
    }
    
  • 代碼解析:

    • 代碼比較簡單, 和之前實現(xiàn)的Set也比較類似, 不再深度解析.

字典的使用

  • 我們來使用和測試一下字典類:

    // 創(chuàng)建字典對象
    var dict = new Dictionay()
    
    // 在字典中添加元素
    dict.set("age", 18)
    dict.set("name", "Coderwhy")
    dict.set("height", 1.88)
    dict.set("address", "廣州市")
    
    // 獲取字典的信息
    alert(dict.keys()) // age,name,height,address
    alert(dict.values()) // 18,Coderwhy,1.88,廣州市
    alert(dict.size()) // 4
    alert(dict.get("name")) // Coderwhy
    
    // 字典的刪除方法
    dict.remove("height")
    alert(dict.keys())// age,name,address
    
    // 清空字典
    dict.clear()
    
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末悲没,一起剝皮案震驚了整個濱河市篮迎,隨后出現(xiàn)的幾起案子男图,更是在濱河造成了極大的恐慌,老刑警劉巖难裆,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亩进,死亡現(xiàn)場離奇詭異谍憔,居然都是意外死亡,警方通過查閱死者的電腦和手機苫昌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門物独,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人瞻凤,你說我怎么就攤上這事≈肟牵” “怎么了?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我仍劈,道長,這世上最難降的妖魔是什么屋群? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任对竣,我火速辦了婚禮否纬,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘膜廊。我一直安慰自己匙瘪,他們只是感情好薄货,可當(dāng)我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般薯蝎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天,我揣著相機與錄音,去河邊找鬼伤提。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赶撰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼卖擅,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了断楷?” 一聲冷哼從身側(cè)響起茅主,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤学搜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡褒纲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年楔绞,在試婚紗的時候發(fā)現(xiàn)自己被綠了耻讽。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片慰枕。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一著洼、第九天 我趴在偏房一處隱蔽的房頂上張望液荸。 院中可真熱鬧忍弛,春花似錦疯兼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蹲嚣。三九已至议惰,卻和暖如春运杭,著一層夾襖步出監(jiān)牢的瞬間虱咧,已是汗流浹背绘沉。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工日矫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留窃诉,地道東北人宣脉。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓践险,卻偏偏與公主長得像,于是被迫代替她去往敵國和親占遥。 傳聞我的和親對象是個殘疾皇子瓦胎,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,592評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)负芋,也就是一...
    悟名先生閱讀 4,145評論 0 13
  • 工廠模式類似于現(xiàn)實生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情毯盈,實現(xiàn)同樣的效果;這時候需要使用工廠模式厂镇。簡單...
    舟漁行舟閱讀 7,750評論 2 17
  • 單例模式 適用場景:可能會在場景中使用到對象,但只有一個實例菩咨,加載時并不主動創(chuàng)建谤饭,需要時才創(chuàng)建 最常見的單例模式揉抵,...
    Obeing閱讀 2,065評論 1 10
  • 如需轉(zhuǎn)載, 請咨詢作者, 并且注明出處.有任何問題, 可以關(guān)注我的微博: coderwhy, 或者添加我的微信: ...
    coderwhy閱讀 8,952評論 5 13
  • 引言 面對越來越多的微服務(wù),越來越頻繁的版本發(fā)布嗤疯,上周末在家倒騰了jenkins+docker的持續(xù)集成和持續(xù)交付...
    編程產(chǎn)品人閱讀 22,101評論 3 40