【退役之重学前端】关于对编程本质的回忆、理解和梳理

理论准备-

  1. 编程的本质,就是对内存中数据的访问和修改。程序所用的数据都会保存在内存中。(《疯狂java第四版》李刚 第49页 )
  2. 字节(byte),字节是计算机存储中的基本单位,由8位二进制数字组成,用于存储单个字符和小的数据单元。在计算机中所有的数据都以字节的形式存储和处理。(AI)
  3. 现代计算机中常以字节数来描述容量的大小,因为一节字节已被定义为8位二进制代码,故用字节数便能反映主存(即内存)容量。(《计算机组成原理第三版》唐溯飞 第17页)。
  4. 比特(bit),来源于binary digit, 意思是一个"二进制数字",因此一个比特就是二进制数字中的一个1或0。(《计算机网络第七版》谢希仁 第21页)
  5. 由第二点和第四点可知,1字节 = 8比特

现在我们来看 JavaScript 中最简单的一条语句,编译器是怎么处理的

javascript 复制代码
var foo = 5;

编译器做的第一件事情,是把它分解成token,然后编译成变量树(作用域链或作用域树)。

当编译器进入到代码生成阶段,它会这样做:

遇到var foo,编译器会向scope查询,看在这个特定的作用域内foo变量是否存在,如果存在,编译器将会忽略这个声明继续执行。否则,编译器会让scope在这个作用域中声明一个叫做foo的新变量,如果不是严格模式的话。

然后编译器生成代码来供引擎稍后执行,以处理foo=5赋值。代码引擎将首先询问scope,是否在当前作用域内能访问到一个叫做foo的变量。如果有,引擎会使用这个变量,如果没有,引擎将会在其他地方查找(将会在之后被覆盖)。

Javascript --- How the Engine Compiles?

Osman Akar

medium.com

在内存中是如何表现的呢?

JavaScript引擎使用作用域树来管理变量,作用域树存储在给JavaScript引擎分配的内存中,而变量值则存储在计算机的内存中。

javascript 复制代码
var foo = 5;

根据以上所述,笔者推论:值(5)存储在计算机的内存中,foo变量存储在作用域树中,并且foo存储的是值(5)所在内存块的地址。

相关推荐
一个博客37 分钟前
pdf-viewer 实现预览pdf文件
开发语言·javascript·pdf
wuxia21189 小时前
微信小程序单击元素切换元素的显示和隐藏
javascript·微信小程序·setdata
JustHappy9 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本9 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_471383039 小时前
图片预解码缓存
前端·浏览器缓存·图片预解码
一起学开源9 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
郑洁文11 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
游九尘11 小时前
JavaScript 实现三段式版本号对比函数(app升级用)
javascript·uni-app
zhiSiBuYu051711 小时前
Claude-Code 新手极速上手指南
javascript·node.js
郑洁文11 小时前
可视化Web渗透分析工具的设计与实现
前端