前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >引用类型、对象拷贝

引用类型、对象拷贝

作者头像
小胖
发布于 2018-06-27 08:03:21
发布于 2018-06-27 08:03:21
74600
代码可运行
举报
运行总次数:0
代码可运行

1.引用类型有哪些?非引用类型有哪些

  • 引用类型 引用类型(对象、数组、函数、正则): 指的是那些保存在堆内存中的对象,变量中保存的实际上只是一个指针,这个指针指向内存中的另一个位置,由该位置保存对象。
  • 非引用类型(基本类型) 基本类型值(数值、布尔值、null和undefined): 指的是保存在栈内存中的简单数据段;

2.代码练习

(1)如下代码输出什么?为什么

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);
// false     
// 因为对象比较的是两个地址,两个对象的地址不同
console.log(obj1 = obj2);
 // Object {a: 1, b: 2} 
// 因为把 obj2 的地址赋给了 obj1
console.log(obj1 == obj2);
// true
// 因为对象比较的是两个地址,前面把地址赋过了,地址相同

(2)如下代码输出什么?为什么

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var a = 1
  var b = 2
  var c = { name: '饥人谷', age: 2 }
  var d = [a, b, c]

  var aa = a
  var bb = b
  var cc = c
  var dd = d

  a = 11
  b = 22
  c.name = 'hello'
  d[2]['age'] = 3

  console.log(aa)   //  1 
        // 基本类型赋值完后互相独立
  console.log(bb)   //  2
        // 基本类型赋值完后互相独立
  console.log(cc)   //  Object {name: 'hello', age: 3}
        // 引用类型赋值完后互相关联,指向同一个对象
  console.log(dd)   //  [1, 2, {name: 'hello', age: 3}]
        // 引用类型赋值完后互相关联,指向同一个对象

(3) 如下代码输出什么? 为什么

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var a = 1
  var c = { name: 'jirengu', age: 2 }

  function f1(n){
    ++n
  }
  function f2(obj){
    ++obj.age
  }

  f1(a) 
  f2(c) 
  f1(c.age) 
  console.log(a)    
  //  输出 1   
  //  因为函数的形参和实参(在这里n是形参,a是实参),是两个变量,如果传递进去的实参保存的是基本类型,形参和外面的变量保存的基本类型的值,互相独立,互不影响
  console.log(c)    
  //  输出 Object {name: 'jirengu', age: 3}
  //  因为函数的形参和实参,是两个变量,如果传递进去的实参保存的是引用类型,形参改变,外面的变量保存着的对象也随之改变

(4) 过滤如下数组,只保留正数,直接在原数组上操作

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
filter(arr)
console.log(arr) // [3,1,2]
-------------------------------
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
    for(var i=0; i<arr.length; i++) {
        if(arr[i]<=0) {
            arr.splice(i,1);
            filter(arr);
        }
    }
}
filter(arr)
console.log(arr)  // [3,1,2]

//或者
var arr = [3,1,0,-1,-3,2,-5]
  function filter(arr){
    for(var i=0; i < arr.length;){
      if(arr[i] <= 0){
        arr.splice(i,1);
      }else{
        i++;
      }
    }
  }
  filter(arr)
  console.log(arr)    //  [3, 1, 2]

(5) 过滤如下数组,只保留正数,原数组不变,生成新数组

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr)  // [3,1,0,-1,-2,2,-5]
-----------------------------------------------------
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
    var newArr = [];
    for(var i=0; i<arr.length; i++) {
        if(arr[i]>0) {
            newArr.push(arr[i]);
        }
    }
    return newArr;
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr)  // [3,1,0,-1,-2,2,-5]

(6)写一个深拷贝函数,用两种方式实现

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
第一种:
function copy(obj){
    var newObj = {};
    for (var key in obj){
        if(obj.hasOwnProperty(key)){
            if(typeof obj[key] ==='number' || typeof obj[key] ==='boolean'
                        || typeof obj[key] ==='string'|| obj[key] === undefined||
                         obj[key] === null){
//对null不能用typeof检测会返回object
            newObj[key] = obj[key];
        }else{
            newObj[key] = copy(obj[key]);
        }
    }   
}
    return newObj;
}
第二种:
JSON.stringify(obj)
JSON.parse()
JSON.parse(JSON.stringify(obj))
function copy(obj){
        var newObj = JSON.parse(JSON.stringify(obj));
        return newObj;
 }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.09.11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
js深拷贝和浅拷贝具体使用区别_es6深拷贝和浅拷贝
对于这个问题,可以考虑从深拷贝和浅拷贝的使用或者起源说起,也就是为什么会出现这个问题。
全栈程序员站长
2022/08/04
6570
面试官想要的 JS 基本类型
面试的时候我们经常会被问答js的数据类型。大部分情况我们会这样回答包括: 基本类型(值类型或者原始类型): Number、Boolean、String、NULL、Undefined以及ES6的Symb
grain先森
2019/04/17
5780
面试官想要的 JS 基本类型
JS拷贝指南:浅拷贝与深拷贝详解
在JavaScript编程中,数据的复制是一个基础而又至关重要的概念,尤其在处理复杂的数据结构时,正确地执行拷贝操作可以避免意料之外的数据修改问题。JavaScript中的数据类型分为基本类型(如number、string、boolean等)和引用类型(如object、array、function等)。基本类型的值存储的是值本身,而引用类型存储的是指向该数据在内存中位置的引用。因此,对于引用类型而言,拷贝操作分为浅拷贝(Shallow Copy)和深拷贝(Deep Copy)两种情况。 浅拷贝:表面的复制 浅拷贝创建一个新的对象或数组,但它仅复制第一层的元素或属性,如果这些元素或属性是引用类型,则新旧对象将共享同一份引用。这意味着对拷贝后对象中引用类型属性的修改会影响到原对象。以下是一些实现浅拷贝的方法:
FGGIT
2024/11/19
4010
深浅拷贝
Object.assign() 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象
hss
2022/02/25
3010
JS浅拷贝与深拷贝
本来只想改变obj2的 value 的值,但是改变之后连obj1的值也一同改变了,很显然,这不是我们想要的的结果。
九旬
2020/10/23
1.6K0
JavaScript 数据结构与算法之美 - 栈内存与堆内存 、浅拷贝与深拷贝
栈内存与堆内存 、浅拷贝与深拷贝,可以说是前端程序员的内功,要知其然,知其所以然。
夜尽天明
2019/07/10
6630
JavaScript 数据结构与算法之美 - 栈内存与堆内存 、浅拷贝与深拷贝
js浅拷贝和深拷贝的区别_前端面试深拷贝和浅拷贝
基本数据类型:Boolean、String、Number、null、undefined 引用数据类型:Object、Array、Function、RegExp、Date等
全栈程序员站长
2022/11/15
1.1K0
js浅拷贝和深拷贝的区别_前端面试深拷贝和浅拷贝
【JS专栏】JS对象的浅拷贝与深拷贝
自己创建一个新的对象,来接受你要重新复制或引用的对象值。如果对象属性是基本的数据类型,复制的就是基本类型的值给新对象;但如果属性是引用数据类型,复制的就是内存中的地址,如果其中一个对象改变了这个内存中的地址,肯定会影响到另一个对象。
Vam的金豆之路
2021/12/01
2.3K0
【JS专栏】JS对象的浅拷贝与深拷贝
面试题:深拷贝和浅拷贝(超级详细,有内存图)
深拷贝和浅拷贝是经常在面试中会出现的,主要考察你对基本类型和引用类型的理解深度。我在无数次的面试中,应聘者还没有一个人能把这个问题回答情况,包括很多机构的培训老师。这篇文章会让你把基本类型和引用类型的区别搞得清清楚楚,搞清楚这两者的区别,你对任何编程语言的都不怕,因为,这不是js一门语言,是任何编程语言中都需要掌握的知识,而且,在任何编程语言中,两者都是一样的。
全栈程序员站长
2022/11/10
5060
面试题:深拷贝和浅拷贝(超级详细,有内存图)
js中的值类型和引用类型的区别
(1)值类型(基本类型):字符串(string)、数值(number)、布尔值(boolean)、undefined、null (这5种基本数据类型是按值访问的,因为可以操作保存在变量中的实际的值)(ECMAScript 2016新增了一种基本数据类型:symbol es6.ruanyifeng.com/#docs/symbo… )
前端老鸟
2019/10/09
3.6K0
js中的值类型和引用类型的区别
js基础之数据类型和拷贝
了解数据类型前先说说栈(stack)和堆(heap) *** stack为自动分配的内存空间,它由系统自动释放;而heap则是动态分配的内存,大小也不一定会自动释放 ***
用户1974410
2022/09/20
3420
js基础之数据类型和拷贝
JS基础知识总结(二):浅拷贝与深拷贝
上一篇JS基础知识总结(一)主要了介绍变量类型相关的基础知识,本文将介绍JS的深拷贝和浅拷贝的有关内容。
前端林子
2018/12/30
2.8K0
JS基础知识总结(二):浅拷贝与深拷贝
js浅拷贝与深拷贝
浅拷贝 只拷贝了基本类型数据和引用类型数据的指针,叫浅拷贝 被拷贝的对象里,如果没有引用类型的数据,可以使用浅拷贝,方便快捷。 如果有引用类型,那么存在被篡改的风险,更应该使用深拷贝 浅拷贝方法 1、手撸一个浅拷贝函数 1function shallowClone(obj) { 2 const newObj = {}; 3 for(let prop in obj) { 4 if(obj.hasOwnProperty(prop)){ 5 newObj[p
心念
2023/01/11
1.1K0
大全!JavaScript中深浅拷贝内部方法与手写函数
怎么理解这句话:浅拷贝过程实质上是创建了一个新的变量,但这个新变量与原变量指向同一个内存地址上的对象。这意味着原对象和拷贝对象共享相同的数据结构和内部状态。因此,对拷贝对象所做的任何修改,如果涉及到修改共享的数据结构,也会影响到原始对象。同样的,原始对象所做的任何修改,如果涉及到修改共享的数据结构,也会影响到拷贝对象。
用户6256742
2024/08/13
1540
深入理解JavaScript中的堆与栈 、浅拷贝与深拷贝
学了这么长时间的JavaScript想必大家对浅拷贝和深拷贝还不太熟悉吧,今天在项目中既然用到了,早晚也要理清一下思路了,在了解之前,我们还是先从JavaScript的数据类型存放的位置 堆栈开始说起吧!
青梅煮码
2023/03/02
2420
前端面试(8)拷贝
js 的基本数据类型的赋值,就是值传递。引用类型对象的赋值是将对象地址的引用赋值。这时候修改对象中的属性或者值,会导致所有引用这个对象的值改变。如果想要真的复制一个新的对象,而不是复制对象的引用,就要用到对象的深拷贝。
leader755
2022/03/09
3200
前端面试(8)拷贝
赋值、浅拷贝、深拷贝的区别
基本类型数据保存在在栈内存中 引用类型数据保存在堆内存中,引用数据类型的变量是一个指向堆内存中实际对象的引用,存在栈中。
木子星兮
2020/07/16
1.1K0
js程序设计02——变量、作用域问题
首先,ECMAScript中的数据类型分为基本类型、引用类型,基本类型的访问操作是按值的。引用类型的值是保存在内存中的对象,操作对象时,实际上操作的是对象的引用,而非对象自身。“javascript高
用户1141560
2017/12/26
9690
js程序设计02——变量、作用域问题
Web前端学习 第3章 JavaScript基础教程19 原始类型
原始类型赋值给变量,遍历存储的是这个值本身,而你用类型赋值给变量,变量存储的是一个引用,这个引用会指向内存中的这个对象。
学习猿地
2020/06/17
3670
JavaScript进阶教程(6)—硬核动图让你轻松弄懂递归与深浅拷贝
递归简单的来说就是程序自己调用自己,就像下面这幅图一样,一直循环往复。就像我们经常听到的小和尚的故事,从前有座山,山里有座庙,庙里有个老和尚和一个小和尚,有一天老和尚对小和尚讲故事,故事内容是:从前有座山,山里有座庙,庙里有个老和尚和一个小和尚,有一天老和尚对小和尚讲故事,故事内容是:从前有座山,山里有座庙,庙里......
AlbertYang
2020/09/16
7140
JavaScript进阶教程(6)—硬核动图让你轻松弄懂递归与深浅拷贝
推荐阅读
相关推荐
js深拷贝和浅拷贝具体使用区别_es6深拷贝和浅拷贝
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验