0

0

JavaScript 的工作原理:了解执行上下文(针对初学者的简化版)

心靈之曲

心靈之曲

发布时间:2024-12-05 14:33:01

|

1027人浏览过

|

来源于dev.to

转载

javascript 的工作原理:了解执行上下文(针对初学者的简化版)

javascript 是世界上最流行的编程语言之一。但它在幕后是如何工作的呢?让我们使用简单的概念和伪代码逐步分解它,以便任何初学者都能理解。


什么是 javascript?

javascript 是一种在浏览器(如 chrome、firefox 或 safari)或服务器上(使用 node.js 等工具)运行的编程语言。它用于使网站具有交互性。当您在浏览器中看到动画、按钮或游戏时,javascript 正在发挥作用。

要了解 javascript 的工作原理,我们需要了解两件事:

  1. 执行上下文
  2. 调用堆栈

什么是执行上下文?

执行上下文就像一个盒子,javascript 保存运行代码所需的一切。这包括:

立即学习Java免费学习笔记(深入)”;

  1. 变量(您存储的数据,例如 x = 5)
  2. 函数(执行某些操作的代码片段,例如 showmessage())
  3. 要执行的代码(您编写的实际指令)

执行上下文主要有两种类型:

  1. 全局执行上下文(gec):这是 javascript 开始运行代码的默认框。就像主舞台一样。
  2. 函数执行上下文(fec):这是每当调用函数时创建的新框。它仅适用于该功能。

分步示例

想象一下你写了这个简单的伪代码:

// global code
var name = "alex";
function greet() {
    var message = "hello, " + name;
    return message;
}
greet();

以下是 javascript 的逐步执行过程:


1.创建全局执行上下文

程序启动时,javascript 会自动创建一个全局执行上下文(gec)

  • 内存(可变环境):

    • name = undefined(暂时占位符)
    • greet = 函数定义(存储greet()的代码)
  • 代码执行阶段:

    android中音频视频开发教程 中文WORD版
    android中音频视频开发教程 中文WORD版

    媒体包提供了可管理各种媒体类型的类。这些类可提供用于执行音频和视频操作。除了基本操作之外,还可提供铃声管理、脸部识别以及音频路由控制。本文说明了音频和视频操作。 本文旨在针对希望简单了解Android编程的初学者而设计。本文将指导你逐步开发使用媒体(音频和视频)的应用程序。本文假定你已安装了可开发应用程序的Android和必要的工具,同时还假定你已熟悉Java或掌握面向对象的编程概念。感兴趣的朋友可以过来看看

    下载
    • 它逐行运行全局代码:
    • var name = "亚历克斯"; → 更新内存:name =“alex”
    • 遇到greet(); → 调用greet函数。

2.创建函数执行上下文

当调用greet()时,javascript会专门为greet创建一个新的函数执行上下文(fec)

  • 内存(可变环境):

    • message = undefined(greet 中变量的占位符)
  • 代码执行阶段:

    • 运行问候函数:
    • var message = "你好," 名字; → 将“hello,”与姓名(“alex”)组合,因此消息 =“hello, alex”。
    • 返回消息; → 回复“你好,亚历克斯”。

3.清理并返回

greet 函数完成后,其 函数执行上下文 就会被移除(删除)。程序返回到全局执行上下文


执行上下文会发生什么?

javascript 使用调用堆栈来跟踪所有这些执行上下文。

什么是调用堆栈?

调用堆栈就像一堆盘子:

  1. 全局执行上下文位于底部(第一块板)。
  2. 每次调用函数时,都会在顶部添加一个函数执行上下文(一个新板)。
  3. 函数完成后,其上下文将被删除(板被取下)。

用伪代码可视化

以下是 javascript 处理我们代码的方式:

  1. 初始全局代码(创建 gec):

    gec:
      memory: { name: undefined, greet: function }
      code: execute global lines
    
  2. 全局执行更新(运行代码):

    gec:
      memory: { name: "alex", greet: function }
      code: encounters greet()
    
  3. 调用greet()(创建fec):

    call stack:
      1. gec
      2. fec for greet()
    fec (greet):
      memory: { message: undefined }
      code: execute function lines
    
  4. 运行greet()并返回:

    fec (greet):
      memory: { message: "hello, alex" }
      return value: "hello, alex"
    call stack after return:
      1. gec
    
  5. 完成执行:

    call stack:
      empty (program ends)
    

要记住的关键事项

  1. 执行上下文就像 javascript 运行代码的容器。每个程序都以全局执行上下文开始,每个函数都有自己的函数执行上下文
  2. 调用堆栈跟踪正在运行的内容。最后添加的内容是第一个删除的内容(lifo:后进先出)。
  3. 当函数完成时,javascript 会进行清理。这就是为什么函数的内存不会永远保留的原因。

为什么这很重要?

理解执行上下文可以帮助您编写更好的程序:

  • 您将知道为什么变量在某些地方可用而在其他地方(范围)不可用。
  • 您将理解诸如“未定义”变量之类的错误。
  • 您将了解函数如何交互以及它们返回值的原因。

挑战自己

尝试在脑海中运行这个伪代码:

var x = 10;
function multiply(y) {
    return x * y;
}
var result = multiply(5);

问自己:

  1. 全局执行上下文中有什么?
  2. 调用multiply() 时会发生什么?
  3. 结果的最终值是多少?

通过掌握执行上下文,您将为解决最棘手的 javascript 问题奠定坚实的基础!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

838

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

744

2023.11.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

397

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

397

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

0

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号