位置: IT常识 - 正文

前端面试:浅拷贝和深拷贝的区别?(前端常见面试)

编辑:rootadmin
前端面试:浅拷贝和深拷贝的区别?

推荐整理分享前端面试:浅拷贝和深拷贝的区别?(前端常见面试),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端面试题简书,前端面试底层原理,前端底层面试题,前端深度面试题,简单的前端面试题,前端深度面试题,前端底层面试题,简单的前端面试题,内容如对您有帮助,希望把文章链接给更多的朋友!

 前些天发现了一个巨牛的人工智能学习博客,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转

那么大家晚上好,我是今天晚上的主讲老师,我是兔哥。

我们在面试中经常会被问到浅拷贝和深拷贝的区别,正好群里也有在问到这个问题,于是今天就专门写一篇博客来讲解一下哈。

1.浅拷贝

浅拷贝是指,对基本类型的值拷贝,以及对象类型的地址拷贝。

怎么讲,什么是基本类型?

在js中,我们知道的基本类型有字符串,数字,布尔值。

当我们写这样的代码,就是浅拷贝。

var a = 1;var b = a; //浅拷贝b = 2; //改变b的值,并不会影响到a,因为浅拷贝对基本类型而言就是值拷贝console.log(a);

a还是1,和b没有关系。

前端面试:浅拷贝和深拷贝的区别?(前端常见面试)

这个道理,在对象中也一样适用。JavaScript中还有对象类型(也叫引用数据类型),对象类型的浅拷贝则只是拷贝了地址。

var p1 = { name: 'jack'}var p2 = p1;p2.name = 'rose';console.log(p1);

p2保存的是和p1一模一样的内存地址,就好像你去配了一把钥匙给张三,张三拿着钥匙一样可以去你家把冰箱里的酸奶喝了。

2.深拷贝

深拷贝是指,除了拷贝基本类型的值,还完全复刻了对象类型。

一个对象在内存中是固定存在的,我们如果要对其进行深拷贝,唯一的办法就是创建一个新的对象,里面的值完全复刻原来的对象。

还是刚才例子,我们稍加改造

var p1 = { name: 'jack'}var p2 = { name: p1.name};p2.name = 'rose';

这样一来,我们对p2进行改造,就不会影响到p1了。这就是深拷贝。

我们用这种方法实现深拷贝是可以的,但是如果属性太多,就会很繁琐。下面讲讲如何实现深拷贝的通用方法?

3.深拷贝 Object.assign()

Object.assign()是一种可以对非嵌套对象进行深拷贝的方法,如果对象中出现嵌套情况,那么其对被嵌套对象的行为就成了普通的浅拷贝。如果没有嵌套,是可以用这个方法的。

var p1 = { name: 'jack'}var p2 = {}Object.assign(p2,p1);

还有一种类似的方法,就是用JSON进行转换

var p1 = { name: 'jack', age:12}var p2 = JSON.parse(JSON.stringify(p1));p2.name = 'rose';

实际开发中,可能这种方式用的更多一些,比如把一些数据转成json存储到本地缓存,需要用到的时候,我们再反序列化。

4.深拷贝递归function deepCopy(dest,src){ var dest = dest || {}; for(var key in src){ //如果对象的属性又是对象,则递归处理 if(typeof src[key] === "object"){ dest[key]= (src[key].constructor === Array)?[]:{}; deepCopy(dest[key],src[key]); }else{ dest[key]=src[key]; } } return dest;}

测试:

var p1 = { name: 'jack', age:12, toy: { name:'car' }}var p2 = deepCopy({},p1);

可以看到,操作p2并不会影响到p1,这就是递归方式的深拷贝。 

今天的分享就到这里啦,也欢迎大家来我们的学习qun交流哦~~

本文链接地址:https://www.jiuchutong.com/zhishi/300025.html 转载请保留说明!

上一篇:简单易懂 关于nextTick()的理解(关于简单的绘画)

下一篇:HTML+CSS+JS 学习笔记(一)———HTML(上)(html/css/javascript)

  • 软件开发费税率17还是6
  • 印花税应税凭证书立日期怎么写
  • 土地价值计入房产税文件
  • 计提税费如何写分录
  • 收到股东投资款怎么做账
  • 销售农产品是否可以抵税
  • 新公司筹建期要做账吗
  • 月利润报表怎么制作
  • 资金结存期末余额方向
  • 调整账户和被调整账户的关系
  • 离境退税政策文件
  • 通信费税前列支的标准和报销票据的要求
  • 税收的三个基本要素是
  • 电子承兑背书失败是怎么回事
  • 管理人员的奖惩制度
  • 公司卖出汽车怎样做账
  • 福利费可以抵扣个税吗
  • 建筑安装企业成本费用包括哪些
  • 特许权使用费的收入确认时间
  • 不需要缴纳增值税的有
  • 新金融工具准则投资收益
  • 长期股权投资账面价值和公允价值不一致
  • 应纳税所得额怎么理解
  • 企业所得税怎么征收
  • 印花税资金账簿税率
  • 利息支出的会计科目
  • ie增强的安全配置已启用上不了网
  • 员工报销可以从一般账户转出吗
  • 非常损失计入
  • 企业所得税优惠事项管理目录
  • 图像分割 unet
  • java htmlparser
  • 税控盘没有报税处理这个选项
  • 金蝶软件凭证修改怎么做
  • 事业单位收入入账
  • 以前月份多扣社保吗
  • dedecmsv6
  • php判断数据库用户名是否存在
  • 公司给员工交社保对公司有什么好处
  • 什么叫网银盾账户
  • 劳务发票进什么科目
  • 食用油交税吗
  • 现金流量表两年数据分析
  • 房屋租赁费可以加计扣除吗
  • 差旅费记入哪个费用
  • 购买材料预付定金填什么凭证
  • 股东实收资本超额到位
  • 损益类科目结转本年利润方向
  • 民办非企业可以开发票吗
  • 营改增租赁服务有哪些
  • 上次年检怎么查
  • 办公用水电费计入什么科目
  • 资产减值损失是费用吗
  • sql语句错误提示
  • sql wind
  • mysql添加myini
  • sql clean
  • windows2000server安装过程
  • linux安装c环境
  • 系统的虚拟内存可以清理吗
  • 硬盘安装windows xp
  • 打开安全启动
  • win7安全防护怎么关闭
  • win10极限精简版 200m
  • 迁移的项目
  • sql怎么设置自增列
  • 图片批量压缩到200k以下
  • javascript怎么用
  • 深入理解android内核
  • js实现超精简的快捷键
  • html5 jquery
  • android基础教程第三版电子版
  • python框架scrapy
  • 山东省省级政务服务区有哪些
  • 税务上成品油换算
  • 税务稽查证据问题
  • 税务总局电子申报软件怎么用
  • 重庆地方税务局2016年2号
  • 四川电子税务局网上办税大厅
  • 房产税是按套还是按套
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设