Map对象,Set对象使用(1)
Map对象:包含所有类型。可以是对象,函数,或字符串等,本质上是键值对的集合
let m = new Map();
let keyarr = [1,23,"发广告"];
let keyfun = function(){}
let keyobj = {"想什么": "无语"};
/*
* 添加键
*/
m.set(keyarr,"我是值");
m.set(keyfun,{});
m.set(keyobj,[123456,10]);
/*
* 读取值
*/
m.get(keyarr);//"我是值"
m.get(keyfun);//{}
m.get(keyobj);//[123456,10]
console.log(m);
上面是Map的两种方法set(),get()(存入和读取)
如果读取未知的键,则返回undefined
。
Map还有size属性,has()方法:
//继续上面的代码
console.log(m.size);//
size属性返回 Map 结构的成员总数。
/*
* has()方法
* has方法返回一个布尔值,表示某个键是否在当前 Map 对象之中。
*/
console.log(m.has("100"));//false
console.log(m.has({ "想什么": "无语" }));//false !?
m.set(false);//这里添加一个布尔值进行判断
console.log(m.has(false));//true
在上面把对应的对象进行了判断。但却给了false,这是为何?(数组和函数一会会提到,别急)
明明Map数据结构中是有这键的,判断却给了false,
其实原因很简单,每个对象都有唯一的地址,即使建立了相同的对象,也还会是false,如果还不明白的继续往下看,
这里需要知道一下堆栈的知识
栈(stack):先进后出;自动分配内存空间,由系统自动释放;使用的是一级缓存,他们通常都是被调用时处于存储空间中,调用完立即释放。
堆(heap):队列优先,先进先出;动态分配内存,大小不定也不会自动释放;存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定;一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。
基本类型有 Undefined、Null、Boolean、Number 和String。这些类型在内存中分别占有固定大小的空间,他们的值保存在栈空间,我们通过按值来访问的。
引用类型,值大小不固定,栈内存中存放地址指向堆内存中的对象。是按引用访问的。当我们需要访问引用数据类型 (对象 / 数组 / 函数) 的值时,首先从栈中获得该对象的地址指针,然后再从堆内存中取得所需的数据。
所以,现在就可以解释 Map中存在的对象,函数,数组 为false了。
再直白点变量a实际保存的是指向堆内存中对象的一个指针,而b保存的是指向堆内存中另一个对象的一个指针;虽然这两个对象的值是一样的,但它们是独立的2个对象,占了2份内存空间;所以 a==b 为 false。
以下再来介绍Map的遍历方法:
Map.prototype.keys()
:返回键名的遍历器。Map.prototype.values()
:返回键值的遍历器。Map.prototype.entries()
:返回所有成员的遍历器。Map.prototype.forEach()
:遍历 Map 的所有成员。
const map = new Map([
['F', 'no'],
['T', 'yes'],
]); for (let key of map.keys()) {
console.log(key);
}
// "F"
// "T" for (let value of map.values()) {
console.log(value);
}
// "no"
// "yes" for (let item of map.entries()) {
console.log(item[0], item[1]);
}
// "F" "no"
// "T" "yes" // 或者
for (let [key, value] of map.entries()) {
console.log(key, value);
}
// "F" "no"
// "T" "yes" // 等同于使用map.entries()
for (let [key, value] of map) {
console.log(key, value);
}
// "F" "no"
// "T" "yes" function logMapElements(value, key, map) {
console.log("m[" + key + "] = " + value);
}
Map([["foo", 3], ["bar", {}], ["baz", undefined]]).forEach(logMapElements);
// logs:
// "m[foo] = 3"
// "m[bar] = [object Object]"
// "m[baz] = undefined"
entries()
方法返回一个新的包含 [key, value]
对的 Iterator
对象,返回的迭代器的迭代顺序与 Map
对象的插入顺序相同。
Map.prototype.clear() : 会移除Map对象中的所有元素。
Map.prototype.delete() : 用于移除 Map
对象中指定的元素。
var map1 = new Map();
map1.set('bar', 'foo'); console.log(map1.delete('bar'));
// expected result: true
// (true indicates successful removal) console.log(map1.has('bar'));
// expected result: false var map1 = new Map(); map1.set('bar', 'baz');
map1.set(1, 'foo'); console.log(map1.size);
// expected output: 2 map1.clear(); console.log(map1.size);
// expected output: 0
最新文章
- int与string类型的转换
- VS:101 Visual Studio 2010 Tips
- xshell xftp
- iOS,图片处理
- 编译Libgdiplus遇到的问题
- 怒刷DP之 HDU 1087
- Hibernate - 使用注解完成映射
- codeforces 388B Fox and Minimal path
- BZOJ 2661 连连看
- (整理)ubuntu 的 相关知识(来自 鸟哥的私房菜)
- CNZZ公告:近期无法获取百度关键词
- jquery控制动态生成的gridview中多列checkbox的全选反选及自动判断是否全选状态
- linux大杂烩
- JSON 和 JSONP 两兄弟
- Android Studio的使用(十二)怎样打包项目
- 【机器学习】--鲁棒性调优之L1正则,L2正则
- 日吞吐万亿,腾讯云时序数据库CTSDB解密
- spring boot+spring data jpa+gradle+mysql配置问题
- xmind 8 便携版:关联文件后,双击打开文件,在当前文件夹产生configuration子文件的问题解决办法
- Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)