数组对象push新的元素,导致其他新复制的数据也发生改变,不是一一对应改变(深拷贝和浅拷贝)

拷贝与浅拷贝?

简单点来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明是浅拷贝,如果B没变,那就是深拷贝。

深入点来说,就是B复制了A,如果B复制的是A的引用,那就是浅拷贝,如果B复制的是A的本体,那就是深拷贝。在深入了解深拷贝和浅拷贝之前,

 

例如设置一个数组

复制代码
var detailList = [{
                    evaluationid:'',
                    name:'请选择左侧体系列表',
                    reason:'',
                    score:'',
                    type:'',
                    objId:'',
                    classname:'',
                }];
//错误push进去
var obj =
that.detailList[0];
this.detailList.push(obj);
复制代码

上面数组增加但是地址指向没有改变,导致数据不能一一对应;

复制代码
var detailList = [{
                    evaluationid:'',
                    name:'请选择左侧体系列表',
                    reason:'',
                    score:'',
                    type:'',
                    objId:'',
                    classname:'',
                }];

var obj =JSON.parse(JSON.stringify(this.detailList[0]));

this.detailList.push(obj);
复制代码

即push操作的是地址指针,而非内存块

posted @   给第一张敬个礼  阅读(953)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示