1. 堆栈
    1. 在javascript中,堆内存是用来存放引用类型的空间环境
    2. 而栈内存,是存储基本类型和指定代码的环境
    3. 在对象中的属性名具有唯一性,数字属性名=字符串属性名,但是在测试的时候你会发现,好像所有属性名都会自动转换成字符串,但事实却不是这样,Symbol就是最好的证明。
      let a={}
      let b=Symbol("1");
      let c=Symbol("1")
      a[b]=123;
      a[c]=123456;
      console.log(a[b]);
      console.log(a);

       

  2. 克隆拷贝:基本都是对于对象或数组而言,以多维对象为例子,也就是对象嵌套对象
    1. 浅拷贝
      1. 只拷贝第一层:对于多重嵌套的对象来说,浅拷贝的意思就是指拷贝第一层,也就是因为对象名只是指向对象再堆中的地址,浅拷贝只是把地址复制一份,而不是重新开辟内存空间。
      2. let obj1={name:"chengjunfeng",
        age:18,
        love:{
        gril:"Mary",
        sport:"run",
        Mary:{
        age:20,
        love:"sing"
        }
        }
        }
        function copy(obj){
        let obj2={};
        for(let key in obj){//只拷贝第一层
        if(!obj.hasOwnProperty(key)) break;//不需要拷贝私有的
        obj2[key]=obj[key];
        }
        return obj2;
        }
        let obj3=copy(obj1);
        console.log(obj1);
        console.log(obj3);
        //当我修改obj3.love.gril的时候,obj1也会变,
        obj3.love.gril="Li";
        console.log(obj3.love.gril);
        console.log(obj1.love.gril); //使用ES6中的解构对象也可以直接实现浅拷贝
        let obj4={...obj1};
        console.log(obj4);
    2. 深拷贝:把对象中的每一层都进行拷贝,可以采用递归的思路
      let obj1={name:"chengjunfeng",
      age:18,
      love:{
      gril:"Mary",
      sport:"run",
      Mary:{
      age:20,
      love:"sing"
      }
      }
      }
      function deepcopy(obj){
      // 递归终止条件
      if(typeof obj !=='object') return obj;
      if(obj===null) return null;
      if(obj instanceof RegExp) return new RegExp(obj);
      if(obj instanceof Date) return new Date(obj);
      let obj2={};
      for(let key in obj){
      if(obj.hasOwnProperty(key))
      obj2[key]=deepcopy(obj[key]);
      }
      return obj2;
      }
      let obj3=deepcopy(obj1);
      console.log(obj1);
      console.log(obj3);
      //当我修改obj3.love.gril的时候,obj1的不会变,
      obj3.love.gril="Liiii";
      console.log(obj3.love.gril);
      console.log(obj1.love.gril); //也可使用JSON进行转换;但是JSON.stringify对于日期函数正则会出错
      let obj4=JSON.parse(JSON.stringify(obj1))
      console.log(obj4);
  3. 闭包
    1. 闭包是指有权访问另一个函数作用域中的变量的函数。创建闭包的常见方式,就是在一个函数1内部创建另一个函数2,函数2就有权访问函数1的变量,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
    2. 闭包会携带包含它的函数的作用域,因此会比其他函数占用更多的内存。


       

javascript中的堆栈、深拷贝和浅拷贝、闭包的更多相关文章

  1. 探究JS中对象的深拷贝和浅拷贝

    深拷贝和浅拷贝的区别 在讲深拷贝和浅拷贝的区别之前,回想一下我们平时拷贝一个对象时是怎么操作的?是不是像这样? var testObj1 = {a: 1, b:2}, testObj2=testObj ...

  2. PHP中对象的深拷贝与浅拷贝

    先说一下深拷贝和浅拷贝通俗理解 深拷贝:赋值时值完全复制,完全的copy,对其中一个作出改变,不会影响另一个 浅拷贝:赋值时,引用赋值,相当于取了一个别名.对其中一个修改,会影响另一个 PHP中, = ...

  3. js 中引用类型 的深拷贝 和 浅拷贝的区别

    一.曾经在读JQ源码的时候,对深拷贝算是有了一点的理解.我们在项目中是不是经常会遇到这样的问题呢? 后台返回一个数组对象(引用类型).次数在页面渲染中需要对部分数据进行处理 比如:银行卡6234509 ...

  4. 谈谈java中对象的深拷贝与浅拷贝

    知识点:java中关于Object.clone方法,对象的深拷贝与浅拷贝 引言: 在一些场景中,我们需要获取到一个对象的拷贝,这时候就可以用java中的Object.clone方法进行对象的复制,得到 ...

  5. Python中复制、深拷贝和浅拷贝的区别

    深拷贝定义(deepcopy) 在Python中,由于一切皆对象,所以任何变量都可以被引用,也即可以被赋值给任何变量.但是在Python中,给变量赋值,是区分的,一般情况下,Python中的变量赋值都 ...

  6. javascript中数组的深拷贝的方法

    一.什么是浅拷贝 在js当中,我们常常遇到数组复制的的情况,许多人一般都会使用"="来直接把一个数组赋值给一个变量,如 var a=[1,2,3]; var b=a; consol ...

  7. Python中什么是深拷贝和浅拷贝且有什么区别

    浅拷贝: >>> a = [1, 2, 3] >>> b = a >>> a [1, 2, 3] >>> b [1, 2, 3] ...

  8. 在js中如何区分深拷贝与浅拷贝?

    一.自我理解 简单来讲就是:深拷贝层层拷贝,浅拷贝只拷贝第一层. 在深拷贝中,新对象中的更改不会影响原对象,而在浅拷贝中,新对象中的更改,原对象中也会跟着改. 在深拷贝中,原对象与新对象不共享相同的属 ...

  9. 睡不着,复习一下C++基础中的基础(深拷贝与浅拷贝)

    #include <iostream> #include <string> #include <assert.h> using namespace std; //声 ...

随机推荐

  1. .net core 使用Tu Share获取股票交易数据

     一.什么是Tu Share Tushare是一个免费.开源的python财经数据接口包.主要实现对股票等金融数据从数据采集.清洗加工 到 数据存储的过程,用户可以免费(部分数据的下载有积分限制)的通 ...

  2. 三.cmdb

    一.服务器管理: https://github.com/rfjer/autoAdmin/tree/master/apps/servers 一服务器信息收集方式: 1.物理服务器 跑脚本传(bash/a ...

  3. spring和springmvc包扫描问题

    写这篇博客之前,橘子松必须感慨下!!找了我一下午加一晚上(md),问了几个朋友也没找到.凉了啊 在搭建ssm之前,我把controller service mapper包扫描用基本包扫描   都写在a ...

  4. git bash中提示 bash:node: command not found

    昨天小伙伴私信,git bash以及windows 的cmd命令行下均无法运行node npm. 究其原因是环境变量的问题.解决步骤: 1>在"此电脑"中右击,选择" ...

  5. CSS通过text-transform实现大写、小写和首字母大写转换

    再日常项目中可能会用到一些特殊的样式,比如大写字母转小写.小写字母转大写.首字母大写等. 可以通过 CSS 的 text-transform 属性来实现: text-transform 转换不同的文本 ...

  6. Linux多任务编程之四:exit()函数及其基础实验(转)

    来源:CSDN  作者:王文松   转自Linux公社 exit()和_exit()函数 函数说明 创建进程使用fork()函数,执行进程使用exec函数族,终止进程则使用exit()和_exit() ...

  7. day58 bootstrap效果无法显示

    在学习bootstrap时直接复制官网的组件的时候,如果效果无法想官网一样显示,最大的可能是类库导入的顺序问题. 打开页面>检查>Console 我们会发现一条报错,导入的js需要jQue ...

  8. day41 几个琐碎知识点

    目录 一.死锁与递归锁(了解) 1 死锁 2 递归锁 二.信息量 三.Event事件 四.三种优先级数据操作 1 队列 2 堆栈 3 自定义优先级 五.进程池和线程池 基本使用 六.协程 七.geve ...

  9. element-ui(vue版)使用switch时change回调函数中的形参传值问题

    需求说明 有多个switch组件 需要知道switch的状态 表格中当前行(scope.row)的数据 问题描述 官方文档中对switch中change的描述: 目前能得到switch的状态值,但是无 ...

  10. # scrapy(二):get请求

    scrapy中的get请求及基本使用: 1. 创建scrapy项目 scrapy startproject QiuBaiProject 2. 创建爬虫文件 scrapy genspider QiuBa ...