首页 > 其他分享 >Map,Set

Map,Set

时间:2023-07-22 15:56:39浏览次数:35  
标签:Map Set console Object let new

Map

Map 对象保存键值对,并且能够记住键的原始插入顺序任何值(对象或者基本类型)都可以作为一个键或一个值

//创建Map只能通过new
const myMap = new Map([
    [1, 'one'],
    [2, 'two'],
    [3, 'three'],
]);
const map1 = new Map();

map1.set('a', 1);
map1.set('b', 2);
map1.set('c', 3);
console.log(typeof map1)//object

for (const map1Element of map1) {
    console.log(map1Element)
}
//[ 'a', 1 ]
//[ 'b', 2 ]
//[ 'c', 3 ]

使用对象的设置属性方法

map1.name = 'tom'
console.log(map1)//Map(3) { 'a' => 1, 'b' => 2, 'c' => 3, name: 'tom' }
console.log(map1.has('name'))//false   
//name并未真正存到map1中,迭代或查询也找不到
for (const map1Element of map1) {
    console.log(map1Element)
}
//[ 'a', 1 ]
//[ 'b', 2 ]
//[ 'c', 3 ]

在Map上存储应该用set(key, value)方法

Map和Object对比

Map Object
意外的键 Map 默认情况不包含任何键。只包含显式插入的键。 一个 Object 有一个原型,原型链上的键名有可能和你自己在对象上的设置的键名产生冲突。备注:虽然可以用 Object.create(null) 来创建一个没有原型的对象,但是这种用法不太常见。
键的类型 一个 Map 的键可以是任意值,包括函数、对象或任意基本类型。 一个 Object 的键必须是一个 String 或是 Symbol
键的顺序 Map 中的键是有序的。因此,当迭代的时候,一个 Map 对象以插入的顺序返回键值。 虽然 Object 的键目前是有序的,但并不总是这样,而且这个顺序是复杂的。因此,最好不要依赖属性的顺序。自 ECMAScript 2015 规范以来,对象的属性被定义为是有序的;ECMAScript 2020 则额外定义了继承属性的顺序。参见 OrdinaryOwnPropertyKeysEnumerateObjectProperties 抽象规范说明。但是,请注意没有可以迭代对象所有属性的机制,每一种机制只包含了属性的不同子集。(for-in 仅包含了以字符串为键的属性;Object.keys 仅包含了对象自身的、可枚举的、以字符串为键的属性;Object.getOwnPropertyNames 包含了所有以字符串为键的属性,即使是不可枚举的;Object.getOwnPropertySymbols 与前者类似,但其包含的是以 Symbol 为键的属性,等等。)
Size Map 的键值对个数可以轻易地通过 size 属性获取。 Object 的键值对个数只能手动计算。
迭代 Map可迭代的 的,所以可以直接被迭代。 Object 没有实现 迭代协议,所以使用 JavaSctipt 的 for...of 表达式并不能直接迭代对象。备注:对象可以实现迭代协议,或者你可以使用 Object.keysObject.entriesfor...in 表达式允许你迭代一个对象的可枚举属性。
性能 在频繁增删键值对的场景下表现更好。 在频繁添加和删除键值对的场景下未作出优化。
序列化和解析 没有元素的序列化和解析的支持。(但是你可以使用携带 replacer 参数的 JSON.stringify() 创建一个自己的对 Map 的序列化和解析支持。参见 Stack Overflow 上的提问:How do you JSON.stringify an ES6 Map? 原生的由 Object 到 JSON 的序列化支持,使用 JSON.stringify()。原生的由 JSON 到 Object 的解析支持,使用 JSON.parse()

Set

Set对象是值的集合,你可以按照插入的顺序迭代它的元素。Set 中的元素只会出现一次,即 Set 中的元素是唯一的

//创建Set只能通过new
const mySet = new Set(['hello',1,2,true,function a(){console.a('hi!~')}])
console.log(typeof myset)//object
console.log(mySet)//Set(5) { 'hello', 1, 2, true, [Function: a] }
mySet.add("some text"); // Set [ 1, 5, "some text" ]
//迭代Set
for (const item of mySet) {
    console.log(item)
}
//hello
//1
//2
//true
//[Function: a]
//some text
// 判断两个集合是否相等
function isSuperset(set, subset) {
    for (let elem of subset) {
        if (!set.has(elem)) {
            return false;
        }
    }
    return true;
}
// Set 和 Array 互换
mySet2 = new Set([1, 2, 3, 4]);
mySet2.size;               // 4
[...mySet2];               // [1,2,3,4]
//合并两个Set
function union(setA, setB) {
    let _union = new Set(setA);
    for (let elem of setB) {
        _union.add(elem);
    }
    return _union;
}
let set1 = new Set([1,2,3,4])
let set2 = new Set([5,6,7,8])
console.log(union(set1, set2))//Set(8) { 1, 2, 3, 4, 5, 6, 7, 8 }
// 找两个Set的交集
function intersection(setA, setB) {
    let _intersection = new Set();
    for (let elem of setB) {
        if (setA.has(elem)) {
            _intersection.add(elem);
        }
    }
    return _intersection;
}
let set1 = new Set([1,2,3,4])
let set2 = new Set([3,4,5,6])
console.log(intersection(set1, set2))//Set(2) { 3, 4 }
//找两个Set的差集
function symmetricDifference(setA, setB) {
    let _difference = new Set(setA);
    for (let elem of setB) {
        if (_difference.has(elem)) {
            _difference.delete(elem);
        } else {
            _difference.add(elem);
        }
    }
    return _difference;
}
let set1 = new Set([1,2,3,4])
let set2 = new Set([3,4,5,6])
console.log(symmetricDifference(set1, set2))//Set(4) { 1, 2, 5, 6 }
//删除A中和B一样的元素
function difference(setA, setB) {
    let _difference = new Set(setA);
    for (let elem of setB) {
        _difference.delete(elem);
    }
    return _difference;
}
let set1 = new Set([1,2,3,4])
let set2 = new Set([3,4,5,6])
console.log(difference(set1, set2))//Set(2) { 1, 2 }

数组去重

const arr = [1,1,1,1,1,2,2,2,2,3,3,3,3,4,4,45,5,5,6,6]
console.log([...new Set(arr)])
[
   1, 2, 3, 4,
  45, 5, 6
]

感谢MDN写出如此优秀的内容,跟着文章敲一遍感觉非常清晰。

标签:Map,Set,console,Object,let,new
From: https://www.cnblogs.com/doud/p/17573487.html

相关文章

  • Unity编辑模式 一键获取Tilemap的格子信息
    动机由于地图是使用unitytilemap编辑的,服务端也希望获取一份相关的信息。相较于自己写个编辑器,直接利用unity的能力会更加敏捷。效果展示只需要将组件拖拽到含有Tilemap组件的GameObj上面,就可以点击按钮,获取格子信息。源码展示[CustomEditor(typeof(TilemapTool))][CanEdi......
  • 内核映射器(KernelMapper)开发-扩展KdMapper在Window 7 x64的支持
    1、背景  内核映射器有较多年历史了,其中KdMapper是比较著名的,原版中它使用intel的驱动漏洞可以无痕的加载未经签名的驱动。只不过当前只支持在Win10及Win11上运行,现在进行功能的修改以支持在Win7x64环境上。当前假定读者对KdMapper的原理比较了解并编译调试过相关代码。 2......
  • file /usr/share/mysql/charsets/macroman.xml from install of MySQL-server-5.6
    MySQL服务器和字符集在使用MySQL数据库时,字符集是一个非常重要的概念。它决定了数据库中存储的数据如何表示和解释。MySQL支持多种字符集,每个字符集都有自己的编码方式和规则。在安装MySQL服务器时,我们可能会遇到如下错误提示信息:file/usr/share/mysql/charsets/macroma......
  • Java8、Java11新特性/Stream/MapReduce
    Q:如果题目里出现了java8的特性,然后问题问你下面哪个命令编译无错那么看下是不是有-java-source8-Xlint:all,是的话就选-source8。Q:JDK8中内置了哪些注解?A:@Override(重点)@Deprecated(重点)@SuppressWarnnings(重点)@SafeVarargs(JDK7引入)@FunctionalInterface(JDK8引入)Q:......
  • set ff=unix
    今天在公司部署项目的时候,执行启动脚本的时候,出现,不能识别这个命令的错误。很纳闷于是寻求同事的帮助,同事说,你需要设置一下这个启动脚本的换行符格式就好了。具体解决办法:使用vi编辑器,执行virun.sh然后输入:setff=unix,使用Unix换行符。然后将run.sh启动脚本中涉及到......
  • .map()
     coords.map(coord=>{.......}解释coords.map(coord=>{...})是一个数组的map方法的使用,用于对coords数组中的每个元素进行遍历并返回一个新的数组。让我们逐步解释这个表达式:coords:这是一个数组,其中包含了一组经纬度坐标的字符串。.map(coord=>{...})......
  • MapReduce原理浅析(转)
    MapReduce原理浅析 -------------------------每天学习一点点^_^-------------------------- 一个简单的应用了Map/Reduce模式的例子:http://wiki.apache.org/hadoop/WordCount   用Mapeduce来处理大数据集的过程,这个MapReduce的计算过程简而言之,就是将大数据集分解为......
  • Competition Set - 在线赛
    一些OnlineJudge上的比赛。洛谷7月月赛IIIA浴眼盯真[过水已隐藏]B众数I给定一个长度为\(n\)的序列\(a\),我们通过以下方式构造序列\(b\):初始时\(b=a\)。依次对\(b\)进行\(k\)次操作,每次操作选择任意一个元素并将其修改为任意整数。定义一个序列的众数......
  • ConcurrentHashMap高频问题
    1:HashMap为啥线程不安全?问题1:JDK1.7里有环(扩容时)。并发+链表头插入导致的, 1.8后改为链表尾插入问题2:数据会覆盖,数据可能丢失。问题3:其次计数器,也是传统的++,在记录元素个数和HashMap写的次数时,记录不准确。问题4:数据迁移,扩容,也可能会丢失数据。2ConcurrentHashMap如何保......
  • python set保存
    Pythonset保存的实现方法一、整体流程下面是实现“Pythonset保存”的步骤和对应的代码:步骤代码步骤1创建一个空的set变量步骤2使用add()方法向set中添加元素步骤3使用update()方法向set中添加另一个set或者list中的元素步骤4使用remove()方法从set中删......