es6學習筆記Set和WeakSet數據結構

Set和WeakSet 數據結構是ES6新增。
它與數組非常相似,但是Set數據結構的成員都是唯一的。
特別說明:Set中只能添加一個NaN。
一.Set數據結構:
var set = new Set([1, 2, 3, 4, 2, 8, 4]); //兩個2
for (var elem of set) {
console.log(elem)
}
//———–循環用add添加賦值———————–
var set = new Set();
[1, 2, 3, 4, 2, 8, 4].map(function (elem) {
set.add(elem);
})
for (let elem of set) { //for…of遍歷
console.log(elem)
}
//——擴展運算符————–
var set = new Set([1, 2, 3, 4, 2, 8, 4]);
var arr = […set];//擴展運算符(…)內部使用for…of循環,
console.log(arr);

//——清空、刪除———-
var set = new Set([1, 2, 3, 4, 2, 8, 4]);
set.clear(); //清空
set.delete(8); //刪除
var arr = […set];
console.log(arr);

//——遍歷鍵值————
set.forEach(function (value, key) {
console.log(value+’=’+key);
})
從輸出結果可以看出,鍵和鍵值是相同的。

//—–判斷set中是否含有—-
console.log(set.has(8));

//—-遍歷值——–
let setIter = set.values();
for(let val of setIter) {
console.log(val);
}
//—-數量———
console.log(set.size);

//——-map和filter也可以用於set中——–
es5中數組新增map和filter方法
map:映射的意思,映射返回一個新數組,有返回值;filterArr:返回一個新對象
var mapArr = array.map(function(value, index, array ){
return value * value;
});

filter:過濾、篩選的意思; 有返回值; filterArr:返回過濾後新數組
var filterArr = array.filter(function(value, index, array ) {
if ( value > 20 ) {
return true;
}
return false;
});
//———————————————
let set = new Set([1, 2, 3]);
set = new Set([…set].map(x => x * 2));
var arr = […set];
console.log(arr);
// 返回Set結構:{2, 4, 6}

let set = new Set([1, 2, 3, 4, 5]);
set = new Set([…set].filter(x => (x % 2) == 0));
var arr = […set];
console.log(arr);
// 返回Set結構:{2, 4}
//—————求並集、交集、差集————–
//因此使用Set可以很容易地實現並集(Union)、交集(Intersect)和差集(Difference)。
let a = new Set([1, 2, 3]);
let b = new Set([4, 3, 2]);
//–求並集
let union = new Set([…a,…b]);
console.log([…union]);
//—就交集
let intersect = […a].filter(function(elem){
return b.has(elem);
});
console.log(intersect);
//—求差集
let difference = […a].filter(function(elem){
return !b.has(elem);
});
console.log(difference);

二.WeakSet數據結構
它與Set十分相似,對象的值也不能是重複的,與Set不同點:
1.WeakSet成員只能夠是對象。
2.作爲WeakSet成員的對象都是弱引用,即垃圾回收機制不考慮WeakSet對該對象的引用,也就是說,如果其他對象都不再引用該對象,那麼垃圾回收機制會自動回收該對象所佔用的內存,不考慮該對象還存在於WeakSet之中。這個特點意味着,無法引用WeakSet的成員,因此WeakSet是不可遍歷的。
3.使用WeakSet存儲對象實例的好處是,由於是對對象實例的引用,不會被計入內存回收機制,所以刪除實例的時候,不用考慮weakset,也不會出現內存泄漏。
//—錯誤—
var weakset = new WeakSet();
weakset.add(5);
//—正確—
var weakset = new WeakSet();
weakset.add({}); //添加
var weakset = new WeakSet([[1, 2], [3, 4]]);
//—例子————————————
var weakset = new WeakSet();
let aObj = {a:’aa’};
let bObj = new String(“你好”);
let cObj = new Number(8);
weakset.add(aObj);
weakset.add(bObj);
weakset.add(cObj);
//—刪除—–
weakset.delete(aObj);
bObj=null; //把對象刪除,weakset中的對象也沒了
console.log(weakset.has(bObj)); //weakset不能取值,也不能顯示,只用來表示是否有重複的對象

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章