const对于复杂类型变量和普通类型变量的区别

我们在开发的过程中一定常常发现const关键字定义的简单类型变量 不可以改变,但是你如果定义的是一个复杂类型变量(比如对象)的话对里面属性的增删改查是可以的,那这又是为什么呢?

看下文

const关键字是让什么不能变?

const实际上的不能变 并不是说变量的值不能变,而是初始化后变量所指向在栈中的内存上的数据不能变

我们先切记这一点先,看下文!!!

js中变量的两种类型

js中的变量类型可以分为两种:

  • 简单数据类型

    1. Number
    2. String
    3. Boolean
    4. Undefined
    5. null
    6. symbol
  • 复杂数据类型(下面我都称为对象)

    1. Object
    2. Array
    3. Function(函数实际上是对象)

两种类型的的存储区别

都是两种数据结构,靠他们来给变量分配使用内存

js的两种数据类型的变量即是存储在堆和栈中

简单类型变量的存储

这种类型的变量我们是用得最多的

它是存储在栈中而已

以下是的示例定义

js 复制代码
var num=100
var bool=false
var str='字符串

而他在栈中的存储可以形象比喻为这样子

其中变量的值 存储在变量指向的栈中的内存地址上,看上图,100就是存储在内存地址上

结合上面所说的const的作用就知道为什么const关键字定义的简单类型的变量的值不能变,因为改变其变量的值是直接改变变量指向的内存上的数据,这是const关键字不允许的

那为什么复杂类型的又可以呢,看下文

复杂类型变量的存储

先说一下,复杂类型的值的更改指的是

复杂类型变量里属性可以更改,整个对象的更改const关键字是不允许的!!!

比如

js 复制代码
const ob={
a:100,
b:200
}
const ob1={
c:100
}
ob.a=200         //   successful ! ! !
ob=ob1           //   fail ! ! !

如果需要替换整个对象,const关键字是不允许的,但是属性值的更改是可以的

那这又是为什么 ? 看下面

我们先要记住const关键字是不允许更改变量的哪个地方,是变量在栈中存储变量值的内存地址上的值

对,没错 !!!这也是普通变量值不能更改的原因

但是为什么复杂变量的可以更改呢,但是不可以替换呢

主要原因是:

复杂变量的值不是存储在栈中,而是存储在堆里,复杂变量在栈中内存上的值是指向存储该复杂类型变量值的堆上的地址

如果这句话看不懂的话,可以看下图

所以更改对象的属性值是更改在堆上的值,而替换对象则是要更改存储在栈中内存地址上变量在堆上存储数据的地址值,而这个更改恰恰是const关键字不允许的!!!

这也是为什么会有对象的浅拷贝和深拷贝的原因,因为你把一个对象直接赋值给另一个对象,准确来说是把对象变量在栈中的存储的指向改变了,指向了同一个在堆里存储的数据,所以你改变其中一个变量的值,会造成其堆上存储的数据改变,所以另外一个对象的值也会改变,这就是为啥会有浅拷贝!!!

相关推荐
Data_Journal1 分钟前
Node.js网络爬取指南——简单易上手!
大数据·linux·服务器·前端·javascript
a11177612 分钟前
可视化角色权限配置页面(html 开源)
前端·开源·html
Lee川19 分钟前
个人中心与 AI 头像生成:从页面到 DALL-E 的完整实现
前端·架构
tedcloud1236 小时前
UI-TARS-desktop部署教程:构建AI桌面自动化系统
服务器·前端·人工智能·ui·自动化·github
UXbot9 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫10 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
PieroPc11 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一12 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen12 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen13 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程