欢迎您访问第A百科网

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

857次浏览     发布时间:2024-03-23 11:27:34     编辑: 前端程序员涛涛

如有错误烦请指正

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)存储全局执行上下文声明的变量,然后进入栈内存执行。

声明变量的步骤

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

var [变量] = [值]

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

所以var a = 12步骤是

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

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

b=13的处理步骤是

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

结果:

总体执行逻辑:

js如何运行(示例2)

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

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

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

这就是第一步,创建值的过程

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

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

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

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

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

顺序如下

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

js如何运行(示例3)

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

当到b = {n: 13};

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

GO global object 全局对象

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

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

注意区分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;

前两行代码执行如下,不在阐述:

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

简单说一下运算符优先级

var a=12,b=13;

相当于

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

相当于

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

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

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

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

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

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

结果:

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

相关文章

单眼皮眼妆的画法步骤图片(可盐可甜的单眼皮眼妆教程)

大大的双眼皮,朦朦胧胧的眼睛好像成了女神小仙女们的标配。但是单眼皮也有单眼皮的美啊,单眼皮的人也可以很迷人,很有辨识度。近年来,纯天然的单眼皮小眼睛越来越受欢迎,单眼皮完全可以美出自己的特色。可以可爱也可以性感像周冬雨、金高银和阿沁这类单眼皮女孩,在一成不变的网红脸里简直是一股清流,让人过目不忘。今

2024-09-20 10:31

淘宝签收了还能退货吗(网购收货7天后发现质量问题还能退货吗?)

网购是当下潮流,给快递行业也带来了新的商机,相信很多消费者都不愿意遇到快递破损或者商品质量有问题的情况,因为退换货还是很麻烦的,为了保护消费者的利益,法律规定消费者可以七天无理由退货。七天期限过后,部分消费者认为不能继续要求退货。事实上,在实践中,即使商品已经签收超过七天,消费者如果发现商品存在质量

2024-09-20 10:16

情人节送老公什么比较实用(情人节适合送给老公的实用礼物)

Xbox游戏机队友早些年还是挺喜欢玩游戏的,但这几年上有老下有小后,我们的生活就越发单一了,除了工作外,每天剩余的时间基本都用来带娃了。年前和队友一起在游戏电玩社体验了双人成行感觉还不错,后来收到年终奖后的第一时间就为队友安排了Xbox SERIES S。因为考虑以后可能会抽时间玩一些双人游戏,所以

2024-09-20 10:01

屈原投的是什么江自尽(屈原为何投汨罗江?)

端午节,中国四大传统节日之一,历来受中国人民以及东亚东南亚地区人民的重视。同时,端午节也是中国所有节日中叫法别称最多的,竟然超过20种叫法:比如龙舟节、粽子节、端阳节、端午节、重五节、龙日节、诗人节、五黄节、午日节、浴兰节、草药节、天医节、五月节等。端午节 古代的端午节可比如今花样多的多了。那时候

2024-09-20 09:45

坐飞机什么东西不能带上机(乘坐飞机哪些东西不能携带)

乘坐飞机时,有一些物品是禁止携带的,主要包括以下几类:枪支、军用或警用械具(含主要零部件)及其仿制品,如弹药、烟火制品、爆破器材等及其仿制品[2][4]。管制刀具,如菜刀、水果刀、大剪刀、剃刀等生活用刀,手术刀、屠宰刀、雕刻刀等专业刀具,以及文艺单位表演用的刀、矛、剑等[2][4]。易燃、易爆物品,

2024-09-20 09:31

打死蛇真的会有报应吗(八大灵性动物,不可杀,不可食)

天生皮骨非天生,只有业障随此身。猫、狗猫狗是和人类最亲近的动物,都通人性,都是我们忠实的朋友。当今社会,豢养宠物盛行,有主人照看的比较安逸,而大量流浪狗、流浪猫却只能靠捡吃垃圾等生存。如果您能发慈悲心,请时常在垃圾箱等地方留点食物给它们充饥,延其生命,必增福报!不能如此,也千万不要无故打杀、虐待猫狗

2024-09-20 09:15

准生证办理流程(新生儿证件办理全攻略!)

1、准生证(计划生育服务证)计划生育服务证是集准生证、查环等功能为一体的证件,多数地方已废除准生证。去办准生证时,拿到的多是计划生育服务证。这是宝宝来到这个世界上的第一个证件,需要提前准备宝宝爸妈的身份证、户口本、结婚证和孕检证明。办理时间:在怀孕前或怀孕后三个月内办理办理地点:户籍所在地或现居住地

2024-09-20 09:01

检察官和律师的区别通俗(法官、检察官、律师哪个职业比较好?)

先说结论:三个专业本身并无好坏之分,关键还要看自身对于未来的规划。一、职业的定位律师(lawyer)是指接受委托或者指定,为当事人提供诉讼代理或者辩护业务等法律服务的人员。法官是指依照法律规定的程序产生,在司法机关(一般指法院)中依法行使国家审判权的审判人员,是司法权的执行者。检察官是依法行使国家检

2024-09-20 08:46

专升本报名流程及条件详细(专升本需要什么条件?)

1、专升本报考不允许跨省首先,专升本考试是由各个省份自行组织的,换句话说,专升本考试是以省为基本单位的,不同省份的招生政策是不同的。在哪个省份读的专科,就只能在哪个省份参加专升本考试,一般来说,不会出现跨省升本的情况。 2、专升本的条件总体上来说,专升本考试针对的是各个省应届毕业的高职高专学生,专项

2024-09-20 08:30

洛可可建筑风格的代表(十大洛可可建筑代表作)

建筑是日常生活中非常常见的,现在的建筑风格一般都是钢筋水泥式的现代建筑,当然也遗留了一些之前的建筑。洛可可式建筑是一个比较特别的建筑风格,比较华丽而美丽世界上有很多地方还遗留着洛可可建筑的身影,下面为大家盘点一下吧。十大洛可可建筑代表作 1、十四圣洁大教堂十四圣洁大教堂始建于1743年德国,1772

2024-09-20 08:15