• 技术文章 >web前端 >js教程

    使用JS原始值与引用值储存

    php中世界最好的语言php中世界最好的语言2018-06-14 11:21:46原创541
    这次给大家带来使用JS原始值与引用值储存,使用JS原始值与引用值储存的注意事项有哪些,下面就是实战案例,一起来看一下。

    原始变量及他们的值储存在栈中,当把一个原始变量传递给另一个原始变量时,是把一个栈房间的东西复制到另一个栈房间,且这两个原始变量互不影响。

    引用值是把 引用变量的名称储存在栈中,但是把其实际对象储存在堆中,且存在一个指针由变量名指向储存在堆中的实际对象,当把引用对象传递给另一个变量时,复制的其实是指向实际对象的指针, 此时 两者指向的 是同一个数据,若通过方法改变其中一个变量的值,则访问另一个变量时,其值也会随之加以改变;但若不是通过方法 而是通过 重新赋值 此时 相当于 重新开了一个房间 该值的原指针改变 ,则另外一个 值 不会随他的改变而改变。

    看示例:

    var a="hello";
    var b=a;
    a="world";
    alert(a);//world
    alert(b);//hello
    var arr=[1,3];
    arr1=arr;
    arr.push(5);
    alert(arr)//1,3,5
    alert(arr1);//1,3,5
    arr=[7,8];
    alert(arr);//7,8
    alert(arr1);//1,3,5

    用图来表示 结果如下:

    原始变量的值互不影响,引用变量arr和arr1指向的为同一对象,所以当对arr通过方法改变其值时(堆房间里的数据发生变化),访问arr1的数据时就会访问到改变后的对象

    通过非方法来改变引用变量的值时,会为该引用变量重新创建一个堆房间,此时指针也会发生变化:

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    css的新属性display:box使用方法

    Vue+bass.scss使用详解

    以上就是使用JS原始值与引用值储存的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:js 原始值 引用值
    上一篇:JS数组扁平化防抖与节流对象拷贝 下一篇:使用nodejs如何操作mongodb的填删改查模块
    VIP会员

    相关文章推荐

    • 浅析Angular中非父子组件间怎么通讯• jquery怎么修改disabled属性的值• jquery怎么清除兄弟元素• jquery怎么获取和失去焦点事件• jquery怎么获取隐藏域中的值

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网