专职C++

不能停止的脚步

  C++博客 :: 首页 :: 联系 :: 聚合  :: 管理
  132 Posts :: 7 Stories :: 134 Comments :: 0 Trackbacks

常用链接

留言簿(13)

我参与的团队

搜索

  •  

最新评论

阅读排行榜

评论排行榜

60天内阅读排行

ES2015开始,javascript默认提供了Set,Map,WeakSet,WeakMap

本文所有的例子都是在node.js 6.9.x下运行通过 
在程序实现中,其实SetMap操作非常多了,C++STL提供了基本于红黑树的SetMap,C++11版本增加了unorder_mapunorder_set,使用C++这方面操作非常方便,并且性能非常高.

 

通过http://node.green/这个网页,可以看到node.js和各版本对ES2015,ES2016,ES2017的支持的情况.

可能看到Node 6.9.xES2015支持度达到99%

基中于Set,Map,WeakSet,WeakMap已经完全支持.这点让我很开心.



那么我在node 6.9.x环境下,可以放心使用了

 

在这里,我记录的是Set

基本例子:

创建Set对象

1.new创建Set

 let s = new Set();

let s = new Set([1,2,3]);

2.add命令增加元素

s.add(5);

也可以用.add连续加多个

s.add(100).add(200);

3.用size属性获取元素个数

console.log(s.size);

注意,不能用s.length,它没有定义这个属性

4.has判断元素是否存在

console.log(s.has(100)); //返回bool结果,true表示有,false表示无

5.for of遍历

for(let e of s) {

console.log(e);

}

也可用forEach

s.forEach(e=>console.log(e));

用ES5方法写:

s.forEach(function (e) {console.log(e);});

用es2015的箭头函数,简洁好多啊

6.delete删除元素

s.delete(100);  //返回bool结果,true表示删除成功,false表示删除失败

s.clear();//则是清除所有的元素

7.关于keys,valuesentries

实际上Set和Map一样,都是以KeyValue的方式存放的,只是Set的Key和Value是一样的。

所以keysvalues返回的都是Key集合。如

let s = new Set([100,200,300]);

s.keys()s.values()返回的都是{ 100, 200, 300 }

而用s.entries()返回的则是{ [ 100, 100 ], [ 200, 200 ], [ 300, 300 ] }

我想这几个函数是为了和Map定义为相同的行为吧。

 

8.注意:不能用add增加多个元素

如:s.add(100,200,300); 实际上,只增加了一个100

s.add([100,200,300]);则是把[100,200,300]做为一个元素加到数组了

let s = new Set();

s.add([100,200,300]);

则得到的s { [ 100, 200, 300 ] }

如果用add加两个{},则集合中,会有两个{}

Let s= new Set();

s.add({}).add({});

则会得到{{},{}};

经过了解,原来集合中,是用===判断两个元素是相等

{}是不同的对象,所以就会出现上面的情况。

posted on 2017-01-11 14:31 冬瓜 阅读(729) 评论(0)  编辑 收藏 引用 所属分类: 原创javascript

只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理