专栏首页coding个人笔记JavaScript内存之栈和堆

JavaScript内存之栈和堆

对于前端来说,平时开发业务代码的时候根本不会关心JavaScript的内存问题,因为根本用不到,也因此对于内存分配没有一点概念。只有理解了内存分配,对于深拷贝和浅拷贝才能真正理解。当然,理解内存分配对JavaScript才会有更深层次的理解。

基本所有程序都有内存的概念,我们只要简单理解JavaScript是怎么分配内存的就够了。JavaScript内存可以理解就分为两块,一个是栈,一个是堆。栈是有序的,拿兵乓球盒子来记忆确实很生动,先进后出。但是我不清楚真正取数据的时候程序是怎么执行的。堆是无序的,里面存放的数据通过指针获取。栈的存取速度大于堆。

我们都知道JavaScript有五个基础数据类型,Undefined、Null、Boolean、Number、String,在JavaScript内存分配中,基础数据类型存放在栈中,引用数据类型Object,也就是Array、Data等存放在堆中,但是栈存储着指向堆的指针地址。

比如:

var a = 1;
var b = 2;
var c = 3;
var d = [1];
var e = {e: 1};

在内存中大概是这样的:

d和c都只是存储一个地址,数据存储在堆中,这个地址指向堆,至于这个地址是什么,我就不知道了,这边我只是参考网上的格式。a、b、c基础数据类型则是直接存储在栈中。

知道了这个,我们就很容易理解

var a = {a: 15, b: 20};
var b = a;
b.a = 30;
alert(a.a);

为什么弹出来的是30了。如下图:

因为a和b都是对象,把a赋值给b的时候,只是把地址赋值给了b,指向的是堆内相同的数据,所以在改变b的数据的时候,堆内数据改变了,但是a和b地址指针相同,所以弹出来的也是30。

知道了基础数据类型和引用数据类型在栈和堆内的存储,深拷贝和浅拷贝是不是就变的很简单,跟知道了GC机制之后理解闭包就容易很多一样。想要真的学习JavaScript这门语言,很多基础知识真的很重要。

(完)

本文分享自微信公众号 - coding个人笔记(gh_2ce38b49dae1),作者:wade

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-07-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JavaScript之内存溢出和内存泄漏

    程序运行出现的错误,就像水杯,满了之后再加水就溢出了。同理,内存溢出就是程序运行所需的内存大于可用内存,就出现内存溢出错误。

    wade
  • Vuex之action

    一般开发使用mutation已经足够,不过官网推荐mutation不要有异步操作,那么为了规范,我们应该把异步操作的方法都放在vuex提供的action里面。

    wade
  • this的指向

    This的指向问题一直是JavaScript的一大核心,很多人都是觉得了解了,但是又模模糊糊。简单概括就是,this的指向永远是指向调用这个this的对象。下面...

    wade
  • win32应用程序性能测试-内存篇

    本文主要讲述windows平台下应用程序性能测试的内存相关的知识,通过本文了解内存基本原理和分析内存占用问题。 一、内存是什么? 1内存分为物理内存和虚拟内存 ...

    腾讯移动品质中心TMQ
  • 堆外内存 之 DirectByteBuffer 详解

    tomas家的小拨浪鼓
  • Android性能优化(三)之内存管理

    在Android的性能优化的各个部分里,内存的问题绝对是最令人头疼的一部分,虽然Android有垃圾自动回收机制不需要手动干预,但也恰因为此,出现内存问题如内存...

    用户2898788
  • 3.2.1虚拟内存的基本概念

    ②当大量作业要求运行时,由于内存不足以容纳所有作业,只能使少数作业先运行,导致多道程序度的下降。

    week
  • Android应用性能优化——内存优化(内附一个内存泄露优化实例)

    自动管理内存和回收机制,垃圾回收器负责回收程序中已经不使用,但是仍然被各种对象占用的内存,将程序员从繁重、危险的内存管理工中解放出来。

    trampcr
  • 纳尼,Java 存在内存泄泄泄泄泄泄漏吗?

    Java 最牛逼的一个特性就是垃圾回收机制,不用像 C++ 需要手动管理内存,所以作为 Java 程序员很幸福,只管 New New New 即可,反正 Jav...

    Java帮帮
  • 解Bug之路-记一次JVM堆外内存泄露Bug的查找

    用户1263954

扫码关注云+社区

领取腾讯云代金券