揭秘 JavaScript:深入探讨提升、临时死区和可变状态

揭秘 javascript:深入探讨提升、临时死区和可变状态

下面我有两行甜蜜而简单的代码。但我可以向你保证,它要么会让你很困惑(因为你忽略了 js 的下划线原则),要么安慰你。

但是它已经加载了如下的知识概念

吊装暂时死区变量(未声明、未初始化、未定义)(奖励)

我的矛盾声明
就像 var、const 和 let 也提升了它们的属性,但它们位于不同的区域。

吊装def(简单/外行版)

我们可以在实际声明之前访问函数和变量。

现在是时候深入了解 js 如何编译和执行我们的两行代码了

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

在 javascript 中,编译器和引擎处理变量声明和赋值的方式可能有细微差别,尤其是在处理 let 和 var 时。
让我们从编译器和执行的角度来分解给定代码的过程:

name = 'ashu';let name;

此时我明确表示,当我们编写 javascript 代码时,第一个解析器和编译器会编译我们的代码,然后进入执行阶段。

编译器视角
第一行: name = ‘ashu’;

编译阶段
javascript 引擎解析代码并创建必要的范围。
作业名称 = ‘ashu’;

会注意到,但是在这个阶段,引擎不会执行代码;它仅记录对名为 name 的变量的赋值的存在。

如果之前没有声明过 name ,编译器会将其视为对全局变量(全局范围内的 var name )的赋值,因为 var 声明是提升并全局可访问的。

第二行: 让名字;

稿定AI社区 稿定AI社区

在线AI创意灵感社区

稿定AI社区 60 查看详情 稿定AI社区

当编译器遇到let名字时;声明,它承认name应该是块作用域的。

编译器将名称放入临时死区(tdz)对于它所属的范围,
意思是它承认名称的存在,但将其标记为未初始化.

let 声明不像 var 那样被提升。

相反,它在作用域中创建一个 绑定,并仅在执行声明时初始化它

执行视角

第一行: name = ‘ashu’;

当 javascript 引擎执行赋值 name = ‘ashu’; 时,
它检查当前范围内名称是否存在。由于 name 是用 let 声明的,但位于 tdz(暂时死区)中, 在 let 声明初始化之前尝试访问它将会导致 referenceerror。

因此,此时name在tdz中,赋值name = ‘ashu’;导致引用错误.

第二行: 让名字;

这一行初始化块作用域内的 name 变量。
此后,名称不再位于 tdz 中,并且可以毫无错误地访问或分配。

现在奖励小费

未声明与未定义与未初始化之间的区别;

undeclare :- 变量尚未声明。
undefined :- 变量已声明但未初始化;
未初始化 :- 变量已定义,但其值将在稍后部分出现。

例如:- const result =multiplyby2(5);

直到函数的返回值将分配给结果,直到那时它将处于未初始化区域。

有趣的事实:-

你知道临时死区最初是为

const装饰的,但他们在**let**中采用了较晚的时间点

参考:-

https://frontendmasters.com/courses/deep-javascript-v3 + 我与 github 副驾驶的类比

以上就是揭秘 JavaScript:深入探讨提升、临时死区和可变状态的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/468387.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 06:26:07
下一篇 2025年11月8日 06:27:11

相关推荐

  • 怎样在C++中实现自动部署?

    在c++++中实现自动部署可以通过使用cmake和ci系统如github actions来实现。1. 使用cmake管理项目构建。2. 配置github actions自动构建和部署。3. 确保跨平台编译设置正确。4. 在部署前运行所有测试用例。5. 加入性能测试监控代码变更对性能的影响。6. 自动…

    好文分享 2025年12月18日
    000
  • 怎样理解C++中的对象生命周期?

    c++++中对象的生命周期包括三个阶段:1) 创建:通过new在堆上或直接定义在栈上;2) 使用:对对象进行操作;3) 销毁:自动作用域结束或手动delete,需注意避免内存泄漏。 理解C++中的对象生命周期,这可不只是简单地知道对象从何而来、到哪里去的问题。它涉及到对象的创建、使用、以及销毁的整个…

    2025年12月18日
    000
  • c++中不能重载的符号 盘点不可重载的操作符号

    c++++中不能重载的符号包括:1. . 成员访问操作符,2. .* 成员指针访问操作符,3. :: 作用域解析操作符,4. sizeof 操作符,5. typeid 操作符,6. const_cast 类型转换操作符,7. dynamic_cast 类型转换操作符,8. reinterpret_c…

    2025年12月18日
    000
  • 如何在C++中声明一个变量?

    在c++++中声明变量的方法包括指定类型和名字,并可进行初始化和作用域管理。1. 声明变量时指定类型和名字,如int myvariable;2. 可以声明多种类型,如float、char、bool等。3. 初始化变量避免未初始化问题,如int count = 0;4. 管理变量作用域,全局变量和局部…

    2025年12月18日
    000
  • 什么是C++中的安装程序?

    c++++中的安装程序不是语言本身的一部分,而是用于部署c++应用的工具。常见的类型包括:1.独立安装程序(如nsis),2.网络安装程序(如wix),3.包管理器(如vcpkg)。创建安装程序需经过准备文件、选择工具、编写脚本、测试和发布等步骤。 C++中的安装程序(Installer)并不是C+…

    2025年12月18日
    000
  • 怎样避免C++中的内存泄漏?

    避免c++++内存泄漏的方法包括:1)使用智能指针,如std::unique_ptr和std::shared_ptr;2)应用raii技术,将资源管理与对象生命周期绑定;3)利用内存检查工具如valgrind或addresssanitizer;4)养成良好的编程习惯,减少手动内存管理并定期进行代码审…

    2025年12月18日
    000
  • 如何在C++中写入文件?

    在c++++中写入文件使用ofstream类。1) 创建ofstream对象并打开文件。2) 选择文件模式,如追加模式(std::ios::app)。3) 实现错误处理,使用异常捕捉。4) 优化性能,使用缓冲区管理。5) 采用raii技术自动管理文件资源。 在C++中写入文件是每个程序员都需要掌握的…

    2025年12月18日
    000
  • 如何在C++中声明一个指针?

    在c++++中声明指针的方法是:在变量名前加上星号()。详细描述如下:1. 声明指针时使用int ptr;的形式。2. 初始化指针时应设为nullptr,避免未定义行为。3. 通过*ptr解引用指针访问数据。4. 避免野指针和悬空指针,释放后应置为nullptr。5. 使用智能指针如std::uni…

    2025年12月18日
    000
  • 如何实现C++中的跨平台构建?

    c++++中的跨平台构建可以通过使用cmake、autotools、meson等构建系统和sdl、boost等平台抽象库来实现。1. 使用cmake进行条件编译和链接,生成不同平台所需的构建文件。2. 利用sdl或boost简化代码,使其在不同操作系统上保持一致性。3. 进行广泛的测试和调试,确保代…

    2025年12月18日
    000
  • 如何在C++中释放动态内存?

    在c++++中释放动态内存使用delete和delete[]操作符。1. 使用delete释放单个对象,如int p = new int; p = 10; delete p;。2. 使用delete[]释放数组,如int* arr = new int[10]; delete[] arr;。避免重复d…

    2025年12月18日
    000
  • C++中的栈和堆内存有什么区别?

    在c++++中,栈和堆的区别在于管理方式和使用场景:1. 栈是自动管理的,适合短期存储,内存有限;2. 堆需手动管理,适合长期存储,内存较大但易泄漏。理解这些差异可提高代码质量和性能。 在C++中,栈和堆是两种不同的内存管理方式,理解它们之间的区别对于编写高效且安全的代码至关重要。让我们深入探讨一下…

    2025年12月18日
    000
  • 什么是C++中的智能指针所有权模型?

    c++++中的智能指针所有权模型通过std::unique_ptr和std::shared_ptr体现:1. std::unique_ptr代表独占所有权,确保资源不会被意外释放;2. std::shared_ptr表示共享所有权,通过引用计数管理资源生命周期,适用于多线程环境。 智能指针在C++中…

    2025年12月18日
    000
  • 如何在C++中使用Lambda表达式?

    在c++++中使用lambda表达式可以简化代码、提高可读性和灵活性。1) lambda表达式是匿名函数对象,可捕获变量并在需要时执行。2) 其一般形式为[捕获列表](参数列表) -> 返回类型 { 函数体 },返回类型可省略。3) 使用时需注意捕获列表的选择、性能、可读性和变量生命周期。la…

    2025年12月18日
    000
  • c++智能指针怎么使用

    c++++智能指针的使用方法包括三种主要类型:1. std::unique_ptr 用于独占所有权,2. std::shared_ptr 用于共享所有权,3. std::weak_ptr 用于解决循环引用。它们基于raii原则,自动管理内存,提升代码的安全性和可维护性。 引言 在编程世界中,C++的…

    2025年12月18日
    000
  • xcode 怎么创建 c++ 项目

    在 xc++ode 中创建 c++ 项目可以通过以下步骤实现:1. 打开 xcode,点击 “create a new xcode project”。2. 选择 “macos” 平台和 “command line tool” 模…

    2025年12月18日
    000
  • c++ 作用域解析运算符怎么用

    在 c++++ 中,作用域解析运算符 (::) 用于明确指定标识符的作用域。1) 解决命名冲突,如访问全局变量 (::count)。2) 访问命名空间成员 (math::calculatearea)。3) 访问类的静态成员 (myclass::staticvar)。合理使用该运算符可以提高代码的清晰…

    2025年12月18日
    000
  • clion 怎么创建 c++ 项目

    在 c++lion 中创建 c++ 项目可以通过以下步骤实现:1. 启动 clion 并点击 “create new project”。2. 选择 “c++ executable” 作为项目类型。3. 设置项目位置,建议使用专门文件夹。4. 选择 c+…

    2025年12月18日
    000
  • Gulc:从头开始建造的C库

    本文开启了一个系列,介绍我正在开发的C99库:Gulc(Generic Utility Library的缩写)。该库主要用于学习和娱乐目的,旨在提供C标准库中安全内存管理和实用功能(如向量和无序映射),以简化C语言编程。未来将持续添加更多功能。 目前,该库包含一个简单的验证系统(类似于断言,但在发行…

    2025年12月18日
    000
  • vs 怎么管理多个 c++ 项目

    在 visual studio 中管理多个 c++++ 项目可以通过创建解决方案和使用 cmake 来实现。1. 创建新解决方案并添加 c++ 项目。2. 使用 cmake 管理项目依赖和配置。通过这些方法,可以高效地组织和维护多个 c++ 项目,提升开发效率。 引言 搞 C++ 开发的朋友们,管理…

    2025年12月18日
    000
  • c++ 内联函数怎么使用

    c++++ 内联函数通过将函数体嵌入调用处来提升性能。1) 使用 inline 关键字定义内联函数,如 inline int add(int a, int b) { return a + b; }。2) 编译器决定是否内联,基于函数大小和复杂度。3) 适用于小型、频繁调用的函数,避免过度使用以防代码…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信