原始值与引用值
原始值:简单的数据即基础数据类型,按值访问。
引用值:由多个值构成的对象即复杂数据类型,按引用访问。
- 动态属性
对于引用值而言,可以随时添加、修改和删除其属性和方法。
javascriptlet person = new Object(); person.name = 'Jason'; person.age = 42; console.log(person.name,person.age);//'Jason',42对于原始值而言,不能有属性,但是尝试给原始值添加属性不会报错。
javascriptlet name = 'Jason'; name.age = 42; console.log(name.age);//undefined
- 复制值
原始值复制的两个变量互相独立,互不干扰。
引用值的复制值实际上是指针,它指向存储在堆内存中的对象,两个变量实际上指向同一个对象。
垃圾回收
JavaScript是使用垃圾回收的语言,通过自动内存管理实现内存分配和闲置资源回收。垃圾回收主要有两种标记策略:标记清理和引用计数。
- 标记清理
垃圾回收程序运行的时候,会标记内存中存储的所有变量。然后,它会将所有在上下文中的变量,以及被在上下文中的变量引用的变量的标记去掉。在此之后在被加上标记的变量就是待删除的了,原因是任何在上下文中的变量都访问不到它们了。随后垃圾回收程序做一次内存清理,销毁带标记的所有值并收回它们的内存。
- 引用计数
其思路是对每个值都记录它被引用的次数。声明变量并给它赋一个引用值时,这个值的引用数为 1。如果同一个值又被赋给另一个变量,那么引用数加 1。类似地,如果保存对该值引用的变量被其他值给覆盖了,那么引用数减 1。当一个值的引用数为 0 时,就说明没办法再访问到这个值了,因此可以安全地收回其内存了。垃圾回收程序下次运行的时候就会释放引用数为 0 的值的内存。引用计数存在的问题:循环引用的数据没法进行回收,因为计数永远不会为0.
Javascript高级程序设计(第四版)--学习记录之变量、内存
Zwq80235202024-06-24 16:45
相关推荐
jingling5551 小时前
vue | 在 Vue 3 项目中集成高德地图(AMap)油丶酸萝卜别吃1 小时前
Vue3 中如何在 setup 语法糖下,通过 Layer 弹窗组件弹出自定义 Vue 组件?Tonya433 小时前
测开学习DAY37J***Q2927 小时前
Vue数据可视化roman_日积跬步-终至千里9 小时前
【强化学习基础(2)】被动强化学习:学习价值函数ttod_qzstudio9 小时前
深入理解 Vue 3 的 h 函数:构建动态 UI 的利器芳草萋萋鹦鹉洲哦9 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化_大龄9 小时前
前端解析excel1***s6329 小时前
Vue图像处理开发
