技术编程|几个例子理解不同数据类型的堆栈内存处理
如有错误烦请指正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 [变量] = [值]
先创建值(执行等号右边)
基本数据类型是直接存储在栈内存当中
引用类型的值,都是开辟一个单独的内存空间(堆内存Heap)存储信息
声明变量 declare存放到当前上下文的变量对象中(VO/AO)
定义(赋值)变量:让变量和值关联到一起,也就是所谓的赋值操作,也叫定义(defined)或指针指向所以var n; //默认值是undefined 未定义
所以var a = 12步骤是
在内存中开辟空间,存储12值
声明变量a
将12赋值给a

文章图片
而var b = a处理是

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

文章图片
在内存中开辟空间,存储13值
因为b已经在当前上下文的变量对象中,所以不需要第二步声明
将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

推荐阅读
- 前瞻网|华大推15分钟新冠快速检测盒,前瞻医疗器械产业全球周报第47期:苹果被起诉窃取血氧监测专利技术
- 极酷数码客|价格很有优势,雷军刚发布行业领先技术!小米新机紧接被曝光
- 麦田军事观察|印度抨击法国公司拒绝转让核心技术啥意义?不知花钱买不来现代化
- 沈潮汐|扬言基建技术超越中国,2天后愣住了,印度3天时间搭好一座桥
- 量子科技,爆发!有项关键技术中国已领先世界
- 男子|47岁大妈与十几个男子发展关系,一个变化让男友们慌了
- 游人馆|和平精英:4AM成功晋级PEL决赛,有几个数据还是蛮有意思的
- 旭宝娱乐|除了白素贞你还记得哪几个?,赵雅芝最经典五个角色
- 歼-20|又一国看上国产战机,关键部位采用歼-20技术,一口气要采购40架
- 一品汽车|“备胎上位”道阻且长,氢燃料电池技术储备不足
