ES6特殊的數(shù)據(jù)結(jié)構(gòu)Set和Map
當(dāng)前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
前言Set為ES6提供的一種新的數(shù)據(jù)結(jié)構(gòu),它類似于數(shù)組,但是成員的值都必須是唯一的,沒有重復(fù)的值。 Map解決了傳統(tǒng)意義是只能將字符串當(dāng)作鍵的問題。 正文SetSet實例的創(chuàng)建const s = new Set(); 一系列方法add(value) : 向集合中添加一個新元素。如果該值已經(jīng)存在,則不會重復(fù)添加。 delete(value) : 刪除集合中的某個值。如果值存在,則返回?true,否則返回?false。 has(value) : 檢查集合中是否包含某個值,返回?true?或?false。 clear() : 清空集合中的所有元素。 size: 屬性,返回集合中元素的數(shù)量。 屬性方法Set.keys():返回鍵名的遍歷器 Set.values():返回鍵值的遍歷器 Set.entries():返回鍵值對的遍歷器 Set.forEach():使用回調(diào)函數(shù)遍歷每個成員 代碼實操:const s = new Set(); s.add(1); s.add(2); console.log(s); console.log(s.keys()); // 鍵名 console.log(s.values()); // 值 console.log(s.entries()); // 鍵值對 還可以通過傳入數(shù)據(jù)的方法來初始化一個Set實例: const s = new Set([1, 2, 3, 3]); 遍歷Set對象的方法const s = new Set([1, 2, 3, 3]); for (let item of s) { // 專門用來遍歷具有iterable(迭代器)屬性的結(jié)構(gòu) console.log(item); } //輸出123 也可以用來遍歷鍵值: const s = new Set([1, 2, 3, 3]); for (let item of s.keys()) { // 專門用來遍歷具有iterable(迭代器)屬性的結(jié)構(gòu) console.log(item); } //輸出123 WeakSetWeakSet 結(jié)構(gòu)與 Set 類似,也是不重復(fù)的值的集合。但是,它與 Set 有兩個區(qū)別: WeakSet 的成員只能是對象和 Symbol 值,而不能是其他類型的值 WeakSet 中的對象都是弱引用,即垃圾回收機制不考慮 WeakSet 對該對象的引用,也就是說,如果其他對象都不再引用該對象,那么垃圾回收機制會自動回收該對象所占用的內(nèi)存,不考慮該對象還存在于 WeakSet 之中 第二點可能有點不太容易理解,通過代碼實例來進行解釋: let obj = {name: '瑪卡巴卡'}; let ws = new WeakSet(); ws.add(obj); obj = null; // 如果一個對象被人為的置為null,一定會第一時間被回收掉 console.log(ws); 總結(jié): 弱引用 一個對象obj存放在了其他的結(jié)構(gòu)中,當(dāng)后續(xù)存在其他對象引用這個對象,那么這個對象的內(nèi)存就不會被回收。 一個對象obj存在了其他的結(jié)構(gòu)中,當(dāng)后續(xù)只存在WeakSet對它的引用,該對象的內(nèi)存依然會被回收。 MapMap實例的創(chuàng)建const m = new Map(); // 可以用任意類型做key 一系列方法set(key, value) : 添加或設(shè)置鍵值對。如果鍵已存在,則更新對應(yīng)的值。 get(key) : 根據(jù)鍵獲取值,如果鍵不存在則返回?undefined。 has(key) : 判斷?Map?中是否存在某個鍵,返回布爾值。 delete(key) : 刪除指定鍵及其對應(yīng)的值,如果刪除成功返回?true,否則返回?false。 clear() : 清空?Map?中的所有鍵值對。 size: 屬性,返回?Map?中鍵值對的數(shù)量。 屬性方法Map.keys():返回鍵名的遍歷器。 Map.values():返回鍵值的遍歷器。 Map.entries():返回所有成員的遍歷器。 Map.forEach():遍歷 Map 的所有成員。 代碼: const m = new Map(); // 可以用任意類型做key const o = {age: 18}; m.set(o, [1, 2, 3]); console.log(m); console.log(m.keys()); console.log(m.values()); console.log(m.entries()); 代碼: const m = new Map(); // 可以用任意類型做key const o = {age: 18}; m.set(o, [1, 2, 3]); m.delete(o); console.log(m.get(o)); console.log(m.has(o)); //輸出undefined false WeakMapWeakMap結(jié)構(gòu)與Map結(jié)構(gòu)類似,也是用于生成鍵值對的集合,但是WeakMap與Map的區(qū)別有兩點: WeakMap只接受對象(null除外)和?Symbol 值作為鍵名,不接受其他類型的值作為鍵名。 WeakMap的鍵名所指向的對象,不計入垃圾回收機制。 WeakMap的專用場合就是,它的鍵所對應(yīng)的對象,可能會在將來消失。WeakMap 結(jié)構(gòu)有助于防止內(nèi)存泄漏。 注意,WeakMap 弱引用的只是鍵名,而不是鍵值,鍵值依然是正常引用。 作者:椰汁33 鏈接:https://juejin.cn/post/7372914724512989211 來源:稀土掘金 著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。 該文章在 2024/5/28 9:32:12 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |