Set 和 WeakSet 数据结构是ES6新增。

它与数组非常相似,但是Set数据结构的成员都是唯一的。

特别说明:Set 中只能添加一个NaN

一、Set 数据结构:

var set = new Set([1,2,3,4,2,8,10])   // 两个2

for (var elem of set) {
  console.log(elem)
}

//-----------循环用 add 添加赋值 --------------

var set = new Set()

[1,2,3,4,2,8,10].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,10])

var arr = [...set]  // 扩展运算符(...)内部使用 for...of 循环

console.log(set)  // [Object set]

console.log(arr)  // 1,2,3,4,2,8,10

//---------------- 清空、删除 --------------------

var set = new Set([1,2,3,4,2,8,10])

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 setlter = set.values() //把所有的值单独拿出来

for (let val of setlter) {
  console.log(val)
}

//------------------ 数量 -------------------------

console.log(set.size)

//------------------- map 和 filter 也可以用于set中--------

es5中数组新增 map 和 filter 方法

map: 映射的意思,映射返回一个新数组,有返回值;mapArr: 返回一个新对象

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])

var arr = [...union]

console.log(arr) // Set {1,2,3,4}

// 交集

let intersect = [...a].filter(x => b.has(x))

即:let intersect = [...a].filter(function(x){
    return b.has(x) // 返回 true,则 x 会被放入 intersect 集合中
  }) console.log(intersect) // Set {2,3}

// 差集

let difference = [...a].filter( x => !b.has(x))

即:let difference = [...a].filter(function(x){
    return !b.has(x)
  }) console.log(difference) // Set {1}

二、WeakSet 数据结构

它与 Set 十分相似,对象的值也不能是重复的,与 Set 不同点:

1.WeakSet 成员只能够是对象

2.作为 WeakSet 成员的对象都是弱引用,即垃圾回收机制不考虑 WeakSet 对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在与WeakSet之中。这个特点意味着,无法引用WeakSet的成员,因此WeakSet是不可遍历的。

3.使用WeakSet存储对象实例的好处是,由于是对对象实例的引用,不会被计入内存回收机制,所以删除实例的时候,不用考虑weaket,也不会出现内存泄漏。                                                         //-----错误------

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不能取值,也不能显示,只用来表示是否有重复的对象

.

Set 和 WeakSet 数据结构的更多相关文章

  1. Set和WeakSet数据结构

    学习Set数据结构,注意这里不是数据类型,而是数据结构.它是ES6中新的东西,并且很有用处.Set的数据结构是以数组的形式构建的. Set的声明 let setArr = new Set(['js', ...

  2. ES6系列_11之Set和WeakSet数据结构

    一.Set 1.Set是什么? Set是ES6 提供的一种新的数据结构.类似于数组. 2.Set能解决什么问题 Set和Array 的区别是Set不允许内部有重复的值,如果有只显示一个,相当于去重. ...

  3. ES6 WeakSet数据结构 与Set十分相似

    它与Set十分相似,对象的值也不能是重复的,与Set不同点: .WeakSet成员只能够是对象. .作为WeakSet成员的对象都是弱引用,即垃圾回收机制不考虑WeakSet对该对象的引用,也就是说, ...

  4. ES6 之 Set数据结构和Map数据结构 Iterator和for...of循环

    ECMAScript 6 入门 Set数据结构 基本用法 ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身是一个构造函数,用来生成Set数据结构. va ...

  5. ECMAScript 6之Set和Map数据结构

    Set 基本用法 ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身是一个构造函数,用来生成Set数据结构. var s = new Set(); [2, ...

  6. es6学习笔记-set和map数据结构

    ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set 本身是一个构造函数,用来生成 Set 数据结构. const s = new Set(); [2, 3 ...

  7. 10.Set 和 Map 数据结构

    Set 和 Map 数据结构 Set 和 Map 数据结构 Set 基本用法 ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set 本身是一个构造函数,用来 ...

  8. ES6的新特性(12)——Set 和 Map 数据结构

    Set 和 Map 数据结构 Set 基本用法 ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set 本身是一个构造函数,用来生成 Set 数据结构. co ...

  9. es6的Set和Map数据结构

    Set 和 Map 数据结构 Set WeakSet Map WeakMap Set § ⇧ 基本用法 ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set ...

随机推荐

  1. Android签名有什么作用?

    应用程序升级:如果你希望用户无缝升级到新的版本,那么你必须用同一个证书进行签名.这是由于只有以同一个证书签名,系统才会允许安装升级的应用程序.如果你采用了不同的证书,那么系统会要求你的应用程序采用不同 ...

  2. 【洛谷】P1052 过河【DP+路径压缩】

    P1052 过河 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙 ...

  3. AOP:声明式事务管理流程

    1. 注册BeanFactoryTransactionAttributeSourceAdvisor @EnableTransactionManagement --> @Import(Transa ...

  4. MySQL5.7添加授权账号及修改默认端口

    1.修改默认端口 打开配置文件 vim /etc/my.cnf 分别添加端口在client.mysql节点 [client] port=15099 [mysqld] port=15099 需要注意se ...

  5. Android Material Design-Working with Drawables(使用Drawable)-(五)

    转载请注明出处:http://blog.csdn.net/bbld_/article/details/40584331 翻译自:http://developer.android.com/trainin ...

  6. ADS-B显示终端6.0

    改动日志 1  更新背景地图. 增加了全国范围内的飞行限制区.飞行危急区.限制区採用黄色区域表示.危急区採用红色区域表示.全部原始资料均来自民航局发布的航行情报资料汇编. 2为解决显示元素过多,屏幕显 ...

  7. GridView 内容自动换行 简单记录

    $("#GridView1 tr td:last-child").each(function () { var width = $(document).width() - 700. ...

  8. (转)rtmp协议简单解析以及用其发送h264的flv文件

    Adobe公司太坑人了,官方文档公布的信息根本就不全,如果只按照他上面的写的话,是没法用的.按照文档上面的流程,server和client连接之后首先要进行握手,握手成功之后进行一些交互,其实就是交互 ...

  9. springmvc整合slf4j、log4j记录文本日志

    一.配置pom.xml 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 3 ...

  10. Java:使用 Java 开发的一个异常处理框架

    背景 这篇文章介绍的异常处理思路不错,本文试图给出一种具体实现,当然可能和作者的思路有所不同. 框架地址:https://github.com/happyframework/HappyFramewor ...