js堆和栈的区别_几个例子理解不同数据类型的堆栈内存处理

如有错误烦请指正

js代码的运行环境

  • 浏览器 内核(引擎)
  • node
  • webview(hybrid,嵌入到手机app里面,在app里面运行)
  • ...

下面通过几个例子理解不同数据类型的堆栈内存处理

js如何运行(示例1)

var a = 12;var b = a;b = 13;console.log(a);

浏览器能够运行js代码,是因为浏览器会在计算机内存中分配出一块内存,用来供代码执行,这块内存叫栈内存,也叫Stack,或者ECStack(Execution Context Stack)执行环境栈

为了区分是哪个区域(全局或者函数等)下的代码执行,会产生一个执行上下文(EC : Execution Context)。所谓执行上下文,其实是一个抽象的概念,简单来理解就是代码执行区域的划分。

在全局环境下会产生 EC(G) :Execution Context (golbal) 全局执行上下文,其中VO(G)全局变量对象(Varibale Object)存储全局执行上下文声明的变量,然后进入栈内存执行。

b717dde3e67f6b37791996cc0a9cf98a.png

声明变量的步骤

接着开始执行,先声明变量,声明变量有三步

var [变量] = [值]

  1. 先创建值(执行等号右边)
    • 基本数据类型是直接存储在栈内存当中
    • 引用类型的值,都是开辟一个单独的内存空间(堆内存Heap)存储信息
  2. 声明变量 declare
    • 存放到当前上下文的变量对象中(VO/AO)
  3. 定义(赋值)变量:让变量和值关联到一起,也就是所谓的赋值操作,也叫定义(defined)或指针指向
    • 所以var n; //默认值是undefined 未定义

所以var a = 12步骤是

  1. 在内存中开辟空间,存储12
  2. 声明变量a
  3. 12赋值给a

89cae2b4d4bb121a71235b6f31f1021f.png

var b = a处理是5fc40723e2a7dcb7031100c29c13c25f.png因为右侧的a不是值,所以不需要第一步,不需要在栈里面开辟空间,直接进行第二步声明,然后执行第三步,关联到12值(指针)

b=13的处理步骤是953ebdecdb77c9d9cc8c6236425e5082.png

  1. 在内存中开辟空间,存储13
  2. 因为b已经在当前上下文的变量对象中,所以不需要第二步声明
  3. 13赋值给b

结果:f2c406ced2feb5df0be08943391dffff.png

总体执行逻辑:

3eedabeb52ce55fe6432697d647908d7.png

js如何运行(示例2)

var a = {n: 12};var b = a;b['n'] = 13;console.log(a.n);

当第一步创建的值是一个引用类型的值时候,值就没法直接存到栈里(没有这么大的空间)。当创建引用类型值的时候,会进行以下处理

  • 在计算机内存中分配一个单独的内存出来(堆内存 Heap)
  • 这块堆内存有一个16进制的地址用来寻找
  • 把对象中的键值对分别存储到堆内存当中
  • 把堆内存地址放置到栈中,供变量调用

这就是第一步,创建值的过程39599b2c7aac552cb396f33b3810240f.png

第二步声明。第三部赋值,将16进制的地址赋值给变量82ecb992359cd149cc6ac530b23be4d3.png

var b = a;时,因为a为 变量,所以不需要创建值,接着声明b,最后赋值,将栈中a指向的地址也同样赋值给b,让b也指向那个16进制地址

1d3d6ea7a85cd2d69a28339ad338e251.png

b['n'] = 13运行原理:

b['n'] = 13属于对象的成员访问

  • b首先基于地址0x000000找到堆内存
  • 把堆内存中成员为n的值改为13
  • console.log(a.n)也属于成员访问 所以输出13

顺序如下

fa5173b6cd67807b88a1fa54f5ac9fb4.png

总结:基本数据类型和引用数据类型的区别?基本类型的值直接存储在栈内存当中,直接按照值操作,引用数据类型值是开辟单独的堆内存存储信息的,将堆内存的地址存在栈当中,操作的都是引用地址

js如何运行(示例3)

var a = {n: 12};var b = a;b = {n: 13};console.log(a.n);

当到b = {n: 13};

新开辟一个堆内存{n: 13},将地址指向b203bcb5256d37c2ca3ab40bec618cd39.png

GO global object 全局对象

不同于VO,VO(G)是全局变量对象,存储当前上下文声明的变量的

GO global object 全局对象,是加载页面默认形成的。在浏览器中,加载页面时,在全局上下文中会默认定义一个叫window的对象,其中有setTimeout,setInterval等供js调用的属性和方法

58ecdbd67160d3704db5223d5a660ab2.png注意区分VO和GO

JavaScript 中有一个特殊的对象,称为全局对象(Global Object),它及其所有属性都可以在程序的任何地方访问,即全局变量在浏览器 JavaScript 中,通常 window 是全局对象, 而 Node。js 中的全局对象是 global,所有全局变量(除了 global 本身以外)都是 global 对象的属性。在 Node。js 我们可以直接访问到 global 的属性,而不需要在应用中包含它。globalprocess__filename__dirname

js如何运行(示例4)

var a = {n: 1};var b = a;a.x = a = {n: 2};console.log(a.x);console.log(b);
var a = {n: 1};var b = a;

前两行代码执行如下,不在阐述:7d70e26fb1e8e62bc7464000c258a831.png

要想理解a.x = a = {n: 2};

简单说一下运算符优先级

var a=12,b=13;

相当于

var a=12var b=13
var a=b=13

相当于

b=13var a=b//或者var a=13

正常计算都是从右到左处理的(当然第一步还是创建值)

但是不管是a.x=b=13还是b=a.x=13都要先计算a.x因为优先级比较高(成员访问的优先级为19,仅次于()运算,运算符优先级 )

a.x = a = {n: 2};运算步骤如下

04a9cfc0dde8ca407291a8dd21d86fa7.png

  1. 开辟内存,假设地址为0x000001
  2. 将地址放入栈中
  3. a.x = 地址 0c3a38752dfecb4e6926166a74aea215.png
  4. a = 地址 83c24576e570f674c0acc8e3df6b89ea.png

所以现在a指向0x000001,b指向0x000000,即a{n:2}b{n:1,x:{n:2}}

结果:f70bab8736b34c768841cbb0aa8a7b41.png

一个变量只可以关联一个栈中的值,但是一个栈中的值,可以被多个变量关联

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/299523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

世界上没有后悔药,时间匆匆,从关注它们开始......

全世界只有3.14 % 的人关注了青少年数学之旅在这个资讯丰富且易获取的时代,越来越多的人不愿意花时间阅读书籍,碎片化阅读成了主流。人们获取的东西多而杂,很难系统、全面。海量信息对人是冲击,更是诱惑。谁不想了解天下奇闻&…

什么?面试官问我Java内存模型!这不得给我加薪?

内存模型的基础 通信  线程之间以何种机制来交换信息 共享内存  隐式通信消息传递  显示通信 同步  程序中用于控制不同线程间操作,发生的相对顺序的机制 共享内存  显式同步消息传递  隐式同步 Java线程线程之间是通过共享内存的方式实现通信的. 内存模型的抽…

使用 Blazor 开发内部后台(四):基于Card组件快速搭建导航首页

James: 本系列为大家介绍如何使用 Blazor 来开发管理后台,有兴趣的朋友欢迎跟着实验,体验 Blazor 开发的高效与乐趣。本系列目录:使用 Blazor 开发内部后台(一):认识Blazor使用 Blazor 开发内部后台&#x…

2020年,朋友圈的正确打开方式!

全世界只有3.14 % 的人关注了青少年数学之旅各位读者朋友们大家好 我是你们的小伙伴上流君我们开始不定期做互推了不是广告,根据兴趣关注感谢理解与支持ღ( ・ᴗ・ )比心有些人,生活离不开朋友圈。朋友圈是他们展示自我、观察世界的…

因为我把JMM原理讲解了一遍,这给足了我涨薪的底气!

一、什么是JMM? JMM指的是Java内存模型,即 Java Memory Model Java内存模型并不是一种实际存在的东西,而是一种人为形成的约定,是一种概念。 关于JMM,我们需要了解一些相关的同步约定 : 线程在解锁前&…

防腐投加器需要加盐吗_果干、果脯、蜜钱、水果脆片,哪个有营养?你吃对了吗?...

时下,追求健美瘦身的年轻人,常把水果千作为零食、加餐的选择之一。大家认为水果干不仅味道好,富含营养素,而且热量低。还有一些人会把果脯、蜜钱、水果脆片等当作新鲜水果的替代品,用以补充营养一认为果 脯、蜜钱的原料…

.NET6正式版将近,70%开发者或面临技术断层!

过往一周,VS2019 发布了最新V16.11,正式支持热重载;.NET6发布了最后一个预览版Preview7,各大新功能宣告完成;随之C#10的新特性也基本成型,好东西很多!各种密集的版本更新,佐证了行业…

一只蝙蝠的自述在朋友圈火了:千万不要再吃野味了!

全世界只有3.14 % 的人关注了青少年数学之旅来源:少女兔(ID:iiilass)、人民日报(ID:rmrbwx)从营养价值上来看野生动物和家养动物的差别微乎其微既不能延年益寿,也不能青春永驻它们不…

掌握JVM 运行时数据区,其实不是很难,加薪也是要技巧可言的!!!

一、概念 Java 内存区域和内存模型是不一样的东西,内存区域是指 Jvm 运行时将数据分区域存储,强调对内存空间的划分。 而内存模型(Java Memory Model,简称 JMM )是定义了线程和主内存之间的抽象关系,即 J…

不要被约束的意思_俗话说:“娶妻不娶颧骨高,嫁汉不嫁连眉梢”,到底什么意思?...

“世有伯乐,然后有千里马。千里马常有,而伯乐不常有。”——《杂说》 唐韩愈传说春秋时期,有个叫伯乐的人很会选马,他选马的时候,并不需要骑着马真刀真枪地跑几圈,只是看看马的骨相、听听马的嘶鸣就能判断出…

终于来了!微软正式推出 VS Code 测试 API

随着 Visual Studio Code 1.59.0 正式版本的发布,全新的插件测试 API 也从试验版本进入了正式版本。自 2020 年 9 月起至今,经过了将近一年及数次版本迭代的打磨,不管是 API 的功能性还是易用性,与首个预览版本相比都获得了极大的…

MariaDB 10的复制 集群 高可用搭建 大表拆分【持续更新中】

视频地址 http://edu.51cto.com/course/course_id-1691.htmlMariaDB 10培训课程第一部分 复制1.基于GTID方式复制配置及注意事项2.基于表的并行复制3.多源复制(MariaDB 10支持多主一从)4.从库延迟如何找到那条执行慢的SQL5.复制异常处理1062,1032错误处理…

c++歌手大赛系统_计人即讯|第十届程序设计大赛

“第十届程序设计大赛”为激发学生学习计算机语言和科学使用计算机的热情,培养独立思考、勇于创新的探索精神和敢闯会创的意志品格,我院于12月5日13时30分在中主阶教201室成功举办了“第十届程序设计大赛”。本次大赛主要考察选手们应用计算机解决生活中…

限时9.9元 | 快速领取数学建模竞赛备战必备技巧与论文详解!

全世界只有3.14 % 的人关注了青少年数学之旅大家晚上好,随着美赛时间的公布以及大大小小的数学建模竞赛的进行,小天经常可以收到来自很多小伙伴们提出的问题,“竞赛中如何去考虑选题?”、“如何进行思路分析?”、“参考…

项目经理问我Java内存区域模型!急急急

也就这么点吧 Java内存区域主要分为:堆,栈,方法区三大部分 1、堆:是内存区域中最大的部分,所有线程共享,其中存放创建的对象和数组。由于堆是垃圾收集器管理的主要区域,因此也叫GC堆。 2、栈…

设计模式之中介者

中介者模式介绍中介者模式中介者模式是一种行为设计模式,能让你减少对象之间混乱无序的依赖关系,该模式会限制对象之间的直接交互,迫使它们通过一个中介者对象进行合作。中介者模式顾名思义,可以用我们平时生活中的房产中介去理解…

你的网页加载太慢了怎么办?

客户反映,“网页速度太慢了!!”,怎么办? 这个问题似乎有些难以解决,慢了就是慢了,也许用户使用就是一个56K猫,也许服务器只有256K的带宽,也许是网页设计有问题&#xff…

看了这个逻辑关系图,才更清晰为何不让你随便外出了

全世界只有3.14 % 的人关注了青少年数学之旅看了这个逻辑关系图,才更清晰为何不让你随便外出了。非常时期,爱国、爱家、爱自己,请近期减少不必要的外出,直到官方宣布疫情解除!转载来源:刘小兔爱画画部分素材…

ef 关联依赖属性_基础巩固之:xmlns属性梳理

转载自&#xff1a;https://www.cnblogs.com/osttwz/p/6892999.html<?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance&q…

高德面试官问我:JVM内存溢出后服务还能运行吗,我一顿操作行云流水

文章开篇问一个问题吧&#xff0c;一个java程序&#xff0c;如果其中一个线程发生了OOM&#xff0c;那进程中的其他线程还能运行吗&#xff1f; 接下来做实验&#xff0c;看看JVM的六种OOM之后程序还能不能访问。 在这里我用的是一个springboot程序。 /*** author &#xff…