js的slice( )函数和浅复制
1.问题
我有一个数组,希望分多次遍历它们,想借助slice()
函数在每次遍历前,得到一些连续的数组元素。
slice()
的官方文档说:
slice() 方法会浅复制(shallow copy)数组的一部分到一个新的数组,并返回这个新数组。
这里说的浅复制该怎样理解?
2.代码
比如我的代码:
var a = ["php", "python", "java", "c++", "matlab", "ruby", "R", "julia"]
var b = a; // 个人认为这个是“浅复制”
b === a // true
var c = a.slice()
// 看了下c的内容:
c
["php", "python", "java", "c++", "matlab", "ruby", "R", "julia"]
c === a // false 为什么是false呢,slice()不是返回浅复制吗?
我对“浅复制”的理解是“赋予相同的内存地址”,所以b===a
是true
,但是c===a
为什么不是true
呢,slice()
返回的不是浅复制吗?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
这个浅复制指的是元素的浅复制, 而不是整个数组的浅复制啊. 数组还是新的, 和原来不是一个
数组是引用数据类型,由于b引用的是a,所以 b===a 返回true,a.slice()生成的是一个新数组,虽然表面上每个数组元素与a的一样,但本质上已经和a没有联系,而这个新数组被 c 引用,所以 c===a 返回false。
很明显,你对“浅复制”的理解是错误的。
slice()
方法会浅复制(shallow copy)数组的一部分到一个新的数组,并返回这个新数组。这个方法会返回一个新数组,出来的结果当然和原来的数组不同。所以,
c === a
肯定是false
。所谓
浅复制
,是指这样的情况:所谓
深复制
是这样的:数组是特殊的对象,两个数组就是两个对象,所以不能单看值相等就认为相等了