我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么理解JS栈和执行上下文

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么理解JS栈和执行上下文

本篇内容主要讲解“怎么理解JS栈和执行上下文”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JS栈和执行上下文”吧!

 栈

栈,存储货物或供旅客住宿的地方,可引申为仓库

数据结构中的栈

栈是一组数据的存放方式,特点是先进后出,后进先出,也有人是通俗的说吃吐原理,最后吃的最新吞出来,看看大概的图示

怎么理解JS栈和执行上下文
怎么理解JS栈和执行上下文

代码小案例

function one() {   function two() {       function three() {           debugger;       }       three();   }   two(); } one();

执行上面的js,debugger可以看到,最新进入的one()-two()-three(),但是执行完后最先出栈的是three()最后是one()

怎么理解JS栈和执行上下文
怎么理解JS栈和执行上下文

内存区域

  • 栈也是是存放数据的一种内存区域

  • 程序运行的时候,需要内存空间存放数据。一般来说,系统会划分出两种不同的内存空间:一种叫做stack(栈),另一种叫做heap(堆)

  • stack是有结构的,每个区块按照一定次序存放,可以明确知道每个区块的大小

  • heap是没有结构的,数据可以任意存放。因此,stack的寻址速度要快于heap  只要是局部的、占用空间确定的数据,一般都存放在stack里面,否则就放在heap里面,所有的对象都存放在heap

function task() {     var a = 1;     var b = 2;     var c = {         name: 'zhufeng',         age: 10     } } task();

上面的 案例 a、b是放在stack, object对象c则存放在heap,当然因为js是类型语言中没有一定要区分放在栈堆的概念。

队列

队列是一种操作受限制的线性表

特殊之处在于它只允许在表的前端进行删除操作,而在表的后端进行插入操作

进行插入操作的端称为队尾,进行删除操作的端称为队头

因为队列只允许在一端插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出线性表;也有一个通俗的说法:吃拉法则,最先吃的就拉出来

怎么理解JS栈和执行上下文

执行上线文(这节重点)

当函数运行时,会创建一个执行环境,这个执行环境就叫执行上下文(Execution Context)

执行上下文中会创建一个对象叫作变量对象(Value  Object),基础数据类型都保存在变量对象中。这里说明一下,执行上下文中不仅仅有变量对象,还有很多的对象比如:this。

引用数据类型的值保存在堆里,我们通过操作对象的引用地址来操作对象

代码示例

function task(){     var a = 1;     var b = {         name:'zhufei'     }     debugger     var c = [1,2,3]; }

这里大家可以看到,a是值是1直接存在栈中,而b、c是对象所以存的是对应的内存地址

怎么理解JS栈和执行上下文

下面的断点大家也可以清晰的看到,当前的执行上下文,varliable object  存的是当前函数执行使用需要用到的变量,其他的没哟

怎么理解JS栈和执行上下文

数据类型(补一个面试常问的)

JS中有七种基本数据类型

  • 六种基本数据类型 Boolean Null Undefined Number String Symbol

  • 一种引用类型 object {} [] /^$/ new Date() Math

到此,相信大家对“怎么理解JS栈和执行上下文”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么理解JS栈和执行上下文

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JavaScript执行上下文和执行栈是什么

本篇内容介绍了“JavaScript执行上下文和执行栈是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是执行上下文?简而言之,执行上
2023-06-27

js怎么创建执行上下文

本篇内容主要讲解“js怎么创建执行上下文”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js怎么创建执行上下文”吧!1、创建一个执行分为两个阶段:创建阶段和执行阶段。2、创建阶段会发生三件事:绑定
2023-06-25

Js怎么存储执行上下文

这篇文章主要介绍“Js怎么存储执行上下文”,在日常操作中,相信很多人在Js怎么存储执行上下文问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Js怎么存储执行上下文”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-25

JavaScript怎么执行上下文

这篇文章主要介绍了JavaScript怎么执行上下文,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、怎么描述执行上下文1.1 本节知识导图:1.2 如果描述执行上下文当函数
2023-06-14

深入理解函数执行上下文this

这篇文章主要为大家介绍了深入理解函数执行上下文this示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

JavaScript中执行上下文的原理是什么

这期内容当中小编将会给大家带来有关JavaScript中执行上下文的原理是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。执行上下文执行上下文是当前代码的执行环境。执行上下文主要是三种类型:全局执行上下
2023-06-15

JavaScript执行上下文中的this怎么使用

这篇文章主要讲解了“JavaScript执行上下文中的this怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript执行上下文中的this怎么使用”吧!前言在对象内部的方
2023-07-05

JavaScript函数执行上下文的this怎么调用

今天小编给大家分享一下JavaScript函数执行上下文的this怎么调用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Ja
2023-07-04

怎么用VBS可执行程序+Xmlhttp下载备份网上文件

这篇文章主要介绍怎么用VBS可执行程序+Xmlhttp下载备份网上文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!今天写程序时突然想到做一个文件的备份,把网站上的数据库备份到本地机上。一个简单的小程序,做成可执行的
2023-06-08

Python with和上下文管理工具怎么用

这篇文章主要介绍了Python with和上下文管理工具怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python with和上下文管理工具怎么用文章都会有所收获,下面我们一起来看看吧。前言如果你有阅读源
2023-06-27

Postman中怎么处理文件上传和下载

在Postman中处理文件上传和下载,可以通过以下步骤进行操作:文件上传:在Postman中创建一个新的请求。在请求的Headers中添加Content-Type为multipart/form-data。在Body选项中选择form-d
Postman中怎么处理文件上传和下载
2024-03-13

python上下文管理器怎么解决异常

这篇文章给大家分享的是有关python上下文管理器怎么解决异常的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、网络爬虫;4、嵌
2023-06-14

Linux中怎么使用sFTP进行上传和下载文件

这篇文章主要讲解了“Linux中怎么使用sFTP进行上传和下载文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux中怎么使用sFTP进行上传和下载文件”吧!sftp是一种安全的文件传
2023-06-27

编程热搜

目录