首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

函数参数的Tyepscript `Final`还是`const`?

在 TypeScript 中,函数参数可以使用 finalconst 关键字来声明。这两个关键字都用于表示参数是只读的,即在函数体内不能对其进行修改。

  1. final 关键字:final 关键字用于表示参数是只读的,并且不能被子类重写。这意味着在继承关系中,子类不能重新定义该参数。使用 final 关键字可以确保参数的值在函数内部不会被修改,提高代码的可靠性和可维护性。
  2. const 关键字:const 关键字用于表示参数是只读的,但它可以被子类重写。这意味着在继承关系中,子类可以重新定义该参数。使用 const 关键字可以确保参数的值在函数内部不会被修改,但允许子类根据需要进行修改。

选择使用 final 还是 const 取决于具体的需求和设计。如果你希望参数在继承关系中不能被重写,可以使用 final 关键字。如果你希望参数在继承关系中可以被重写,可以使用 const 关键字。

以下是一些应用场景和示例:

  1. 应用场景:
    • 当你希望确保函数参数在函数内部不被修改,并且不允许子类重写时,可以使用 final 关键字。
    • 当你希望确保函数参数在函数内部不被修改,但允许子类根据需要进行修改时,可以使用 const 关键字。
  2. 示例:// 使用 final 关键字 class Parent { public method(final param: number): void { // param = 10; // 编译错误,final 参数不能被修改 console.log(param); } }

class Child extends Parent {

代码语言:txt
复制
 // public method(final param: number): void { // 编译错误,final 参数不能被重写
代码语言:txt
复制
 //   console.log(param);
代码语言:txt
复制
 // }

}

const parent = new Parent();

parent.method(5); // 输出: 5

const child = new Child();

child.method(10); // 输出: 10

// 使用 const 关键字

class Parent {

代码语言:txt
复制
 public method(const param: number): void {
代码语言:txt
复制
   // param = 10; // 编译错误,const 参数不能被修改
代码语言:txt
复制
   console.log(param);
代码语言:txt
复制
 }

}

class Child extends Parent {

代码语言:txt
复制
 public method(const param: number): void {
代码语言:txt
复制
   param = 20; // 子类可以根据需要修改 const 参数
代码语言:txt
复制
   console.log(param);
代码语言:txt
复制
 }

}

const parent = new Parent();

parent.method(5); // 输出: 5

const child = new Child();

child.method(10); // 输出: 20

代码语言:txt
复制

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云函数计算(云函数):云原生的事件驱动型无服务器计算服务,支持多种语言编写函数,实现按需计算,无需管理服务器。详情请参考:腾讯云函数计算
  • 腾讯云云数据库 MySQL:腾讯云提供的高性能、可扩展的关系型数据库服务,适用于各种规模的应用程序。详情请参考:腾讯云云数据库 MySQL
  • 腾讯云云服务器(CVM):腾讯云提供的弹性计算服务,提供安全、可靠、高性能的云服务器,支持多种操作系统和应用场景。详情请参考:腾讯云云服务器
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

GNU C++的符号改编机制介绍[转]前言正文

众所周知,强大的C++相较于C增添了许多功能。这其中就包括类、命名空间和重载这些特性。 对于类来说,不同类中可以定义名字相同的函数和变量,彼此不会相互干扰。命名空间可以保证在各个不同名字空间内的类、函数和变量名字不会互相影响。而重载可以保证即使在同一个命名空间内的同一个类中,函数名字也可以相同,只要参数不一样就可以。 这样的设计方便了程序开发者,不用担心不同开发者都定义相同名字的函数的问题。但是,这也使得符号管理变得更为复杂。 对于在不同类中的同名函数,或者在不同名字空间中的同名函数,或者在同一名字空间或类中的同名重载函数,在最终的编译和链接过程中是怎么将它们区分开来的呢?为了支持C++这些特性,人们发明了所谓的符号改编(Name Mangling)机制。 其原理其实很简单,就是按照函数所在名字空间、类以及参数的不同,按照一定规则对函数进行重命名。不同的编译器其命名规则都不尽相同,这里我们主要介绍GNU C++编译器所使用的规则。主要分为以下几种情况: 1)全局变量: 即在命名空间和类之外的变量,改编后的符号名就是变量名,也就是不做任何修改。 2)全局函数: 以“_Z”开头,然后是函数名字符的个数,接着是函数名,最后是函数参数的别名。 关于函数参数的别名,后面还会有详细的介绍。 3)类或命名空间中的变量或函数: 以“_ZN”开头,然后是变量或函数所在名字空间或类名字的字符长度,然后接着的是真正的名字空间或类名,然后是变量或函数名的长度和变量或函数名,后面紧跟字母“E”,最后如果是函数的话则跟参数别名,如果是变量则什么都不用加。 4)构造函数和析构函数 以”_ZN”开头,然后是构造函数所在名字空间和类名字的字符长度,然后接着的是真正的名字空间或类名,然后构造函数接“C1”或者“C2”,析构函数接“D1”或者“D2”,然后加上字母“E”,最后接函数参数别名结束。 介绍完命名规则,下面我们再具体介绍一下函数参数别名的规则。主要分为下面几种情况: 1)函数参数是基本类型时 每个基本类型的别名如下表:

04

希尔排序是一种…排序方法_希尔排序法属于

(1)插入排序的基本方法是:每步将一个待排序的元素,按其排序码大小插入到前面已经排好序的一组元素的适当位置上去,直到元素全部插入为止。 (2)可以选择不同的方法在已经排好序的有序数据表中寻找插入位置,依据查找方法的不同,有多种插入排序方法。下面是常用的三种。 1>直接插入排序 2>折半插入排序 3>希尔排序 (3)直接插入排序基本思想:当插入第i(i>1)个元素时,前面的data[0],data[1]……data[i-1]已经排好序。这时用data[i]的排序码与data[i-1],data[i-2],……的排序码顺序进行比较,找到插入位置即将data[i]插入,原来位置上的元素向后顺序移动。 (4)折半插入排序基本思想:设元素序列data[0],data[1],……data[n-1]。其中data[0],data[1],……data[i-1]是已经排好序的元素。在插入data[i]时,利用折半搜索法寻找data[i]的插入位置。 (5)希尔排序的过程相比前两种有些不同,下面我们主要介绍希尔排序的过程实现。

02
领券