typescript-引用和const常量

什么是常量?

常量就是"值不会发生变化"的量。

这里大家注意,为什么"值不会发生变化"会加引号?这要根据不同类型的数据来进行区分。

在之前我们讲到过变量,那些变量都是一些基本类型的。今天顺便说一下引用类型的。

什么是引用类型?

就是ts中的一些复杂类型数据。比如数组,Object,对象...就是除了基本类型都是引用类型。

基础类型是放在栈中,可以快速访问。

而引用类型是放在堆中,无序的,可以放复杂的对象数据。

(这块的话,大家需要了解一些计算机原理的知识,大家可以网上搜一下,这里是大概提一下)

看下面的例子吧,结合例子说一下

TypeScript 复制代码
const a = 9;
const c = [1, 2];
// a = 10;
// c = [5, 6];
console.log(a);
console.log(c);
console.log("divide line-------------");
c[0] = 22;
console.log(a);
console.log(c);

以上例子中,如果把// 注释的部分放开,执行tsc index.ts的时候会报错,提示常量无法进行赋值。

但是,看倒数第三行可以把c[0]设置为22。这里不会报错。

是因为这里的c指向的是一个数组[1,2],准确的说是指向的这个数组在栈中的地址,而真正的数组数据是在堆中的,栈中的地址指向堆中的数据。所以,直接更改c的指向(即把c=[5,6])会报错。而更改c指向的数组中的某个值确不会有问题。

相关推荐
鹿心肺语11 小时前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
海石11 小时前
去到比北方更北的地方—2025年终总结
前端·ai编程·年终总结
一个懒人懒人12 小时前
Promise async/await与fetch的概念
前端·javascript·html
Mintopia12 小时前
Web 安全与反编译源码下的权限设计:构筑前后端一致的防护体系
前端·安全
输出输入12 小时前
前端核心技术
开发语言·前端
Mintopia12 小时前
Web 安全与反编译源码下的权限设计:构建前后端一体的信任防线
前端·安全·编译原理
林深现海12 小时前
Jetson Orin nano/nx刷机后无法打开chrome/firefox浏览器
前端·chrome·firefox
黄诂多12 小时前
APP原生与H5互调Bridge技术原理及基础使用
前端
前端市界12 小时前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github
文艺理科生12 小时前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构