es6 set和weakset
来源:互联网 发布:node2vec 知乎 编辑:程序博客网 时间:2024/05/21 11:34
五.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不能取值,也不能显示,只用来表示是否有重复的对象
- es6 set和weakset
- ES6--set集合和WeakSet集合
- ES6中Set和WeakSet的使用
- ES6中Set和WeakSet的使用
- es6学习笔记Set和WeakSet数据结构
- ES6中Set和WeakSet的使用
- ES6-新数据结构Set与WeakSet
- ES6学习之路(六) Set&WeakSet
- 从零开始学_JavaScript_系列(44)——ES6新增数据结构:Set类型和WeakSet
- es6 javascript的WeakSet数据结构
- 【ES6】set和map
- 【es6】Set 和 Map
- ES6--Set 和 Map
- ES6学习之路8----WeakSet数据结构
- SE6新特性之集合Set、Map、WeakSet和WeakMap详解
- WeakSet
- ES6中的Map和Set
- es6 set和map数据结构
- https的传输方式
- Java中this的用法及在构造器中调用构造器
- Quartz两种不同类型的Trigger实现
- nrf52832增大数据吞吐量
- Java--排序算法
- es6 set和weakset
- HDOJ HDU 1034 Candy Sharing Game
- 继承中的static关键字
- HDU 1175 连连看 DFS
- 数组去重的五种方式
- 素数打表(两种方法)
- ASP.NET MVC上传文件的几种方法
- Eclipse快捷键把一段代码向左右移动和注释一块代码
- GBDT与随机森林区别