深浅拷贝

// 注意: 基本数据类型不存在深浅拷贝,只是值传递,复合数据类型才有深浅拷贝之说

        var obj1 = { name: "吴亦凡" };
        var obj2 = obj1;
        obj1.name = "罗志祥";

        // 相当于把obj1的指针复制了一份给了obj2,两个指针指向了堆内存中的一块内存地址,改变其中一个会影响另外一个(浅拷贝)
        // 复合数据类型直接赋值就是浅拷贝操作
        console.log(obj2.name);//罗志祥

        // 复制一个复合数据类型,改变其中一个,另一个不受影响,两个对象是独立的,这样的拷贝就是深拷贝
        var obj3 = { name: "李云迪" };
        var obj4 = {};
        for (const k in obj3) {
            // k===> "name"
            // obj4.name=obj3.name
            // obj4.name="李云迪"
            obj4[k] = obj3[k]
        }

        obj3.name="李易峰";
        console.log(obj4.name);//李云迪
        // 总结: 深拷贝和浅拷贝的区别?
            //  浅拷贝只是增加了一个指针,指向了已经存在的内存地址,如果原来的对象发生了变化,那么浅拷贝出来的对象也会改变
            // 深拷贝是申请了一块新的内存,增加了一个指针,两个指针指向不同的内存地址,两个对象互不影响

//  另一种说法
    // 浅拷贝(shallow copy):只复制指向某个对象的指针,而不复制这个对象本身,新旧对象共享一块内存。
    // 深拷贝(deep copy):复制并创建一个一模一样的对象,不共享内存,修改新对象旧对象不会变。

原文链接:https://www.cnblogs.com/huwenlong/p/17248404.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:深浅拷贝 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • Chart.js功能与使用方法小结

    Chart.js功能与使用方法小结 什么是Chart.js Chart.js是一款简单灵活的JavaScript图表库,可以用于绘制各种类型的图表,包括线图、柱状图、雷达图、饼图等等。Chart.js基于HTML5的Canvas元素实现,具有良好的兼容性和性能优势。 安装与引入 在使用Chart.js之前,需要先进行安装和引入。可以通过以下方式进行安装: n…

    JavaScript 2023年6月11日
    00
  • jsPDF导出pdf示例

    以下是关于如何使用jsPDF导出pdf的详细攻略,包含两个示例。 什么是jsPDF jspdf是一个用于生成PDF文件的JavaScript库。它可以在浏览器端和Node.js环境中使用。它可以轻松地将HTML内容转换为PDF文件,例如HTML文本,SVG图像等。 安装jsPDF 你可以通过npm安装jsPDF: npm install jspdf –sa…

    JavaScript 2023年5月27日
    00
  • js实现弹框效果

    如何通过JavaScript实现弹框效果呢?下面是一些步骤和示例代码来帮助你实现这个功能: 步骤一:创建弹出框的 HTML 代码 首先,要在 HTML 代码中创建弹出框的模板,可以使用 <div> 标签来实现: <div id="myModal" class="modal"> <div c…

    JavaScript 2023年5月27日
    00
  • js实现删除json中指定的元素

    下面是如何实现删除JSON中指定元素的攻略: 1. 找到要删除的元素 在删除JSON中指定元素时,首先要找到要删除的元素。我们可以使用JavaScript的filter()或splice()方法来操作JSON对象。 利用filter()方法: let data = [ {id: 1, name: ‘Alice’}, {id: 2, name: ‘Bob’},…

    JavaScript 2023年5月27日
    00
  • Chrome中JSON.parse的特殊实现

    谈论Chrome中JSON.parse的特殊实现需要先了解JSON.stringify()和JSON.parse()这两个API的作用。其中,JSON.stringify()可以将一个JavaScript对象或数组转换成一个JSON字符串,而JSON.parse()则可以将JSON字符串转化为JavaScript对象或数组。 我们来看一个例子: var ob…

    JavaScript 2023年5月27日
    00
  • JavaScript的History API使搜索引擎抓取AJAX内容

    JavaScript的History API是HTML5标准中新增加的一个API,主要用来处理浏览器的历史记录和URL。同时,它也提供了许多操作浏览器历史记录的方法,其中的一个重要的方法就是pushState()。pushState()方法能够把state对象和修改后的URL添加到浏览器的历史记录中,而且并不会刷新页面。 通过使用pushState()方法,…

    JavaScript 2023年6月11日
    00
  • js获取判断上传文件后缀名的示例代码

    当需要上传文件时,有时我们需要判断文件的后缀名是否符合规范,例如只支持上传jpg、png、gif等图片格式。这时我们可以通过 JavaScript 来获取并判断上传文件的后缀名是否符合要求。下面是获取判断上传文件后缀名的示例代码的完整攻略: 1. 获取上传的文件信息 在 HTML 中,我们需要使用 <input> 标签的 type 属性为 “fi…

    JavaScript 2023年5月27日
    00
  • Javascript aop(面向切面编程)之around(环绕)分析

    JavaScript AOP(面向切面编程)是一种可以帮助我们在不改变原有代码的前提下,在代码执行前、中、后插入新的逻辑的编程技术。其中,Around(环绕)是AOP的一种实现方式,它可以在目标方法被调用之前和之后执行自定义的方法。 下面是使用JavaScript实现Around AOP的完整攻略。 1. 定义目标方法 首先,我们需要定义一个目标方法,也就是…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部