• Swift5.3 语言指南(十四) 下标


    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
    ➤微信公众号:山青咏芝(shanqingyongzhi)
    ➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/
    ➤GitHub地址:https://github.com/strengthen/LeetCode
    ➤原文地址:https://www.cnblogs.com/strengthen/p/9739175.html 
    ➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
    ➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

    类,结构和枚举可以定义下标,这些下标是用于访问集合,列表或序列的成员元素的快捷方式。您可以使用下标按索引设置和检索值,而无需使用单独的方法进行设置和检索。例如,您可以访问在元素Array实例作为someArray[index]和元素的Dictionary实例作为someDictionary[key]

    您可以为单个类型定义多个下标,然后根据传递给下标的索引值的类型选择要使用的适当下标重载。下标不限于单个维度,您可以定义具有多个输入参数的下标以满足您的自定义类型的需求。

    下标语法

    通过下标,您可以通过在实例名称后的方括号中写入一个或多个值来查询类型的实例。它们的语法与实例方法语法和计算属性语法相似。您可以使用subscript关键字编写下标定义,并以与实例方法相同的方式指定一个或多个输入参数和一个返回类型。与实例方法不同,下标可以是读写的或只读的。此行为由getter和setter传递,其方式与计算属性相同:

    1. subscript(index: Int) -> Int {
    2. get {
    3. // Return an appropriate subscript value here.
    4. }
    5. set(newValue) {
    6. // Perform a suitable setting action here.
    7. }
    8. }

    的类型newValue与下标的返回值相同。与计算属性一样,您可以选择不指定设置器的(newValue)参数。newValue如果您自己不提供设置程序,则将默认参数称为提供给设置器。

    与只读计算属性一样,可以通过删除get关键字及其括号来简化只读下标的声明

    1. subscript(index: Int) -> Int {
    2. // Return an appropriate subscript value here.
    3. }

    这是一个只读下标实现的示例,该示例定义了一种TimesTable表示整数n次表的结构:

    1. struct TimesTable {
    2. let multiplier: Int
    3. subscript(index: Int) -> Int {
    4. return multiplier * index
    5. }
    6. }
    7. let threeTimesTable = TimesTable(multiplier: 3)
    8. print("six times three is (threeTimesTable[6])")
    9. // Prints "six times three is 18"

    在此示例中,TimesTable创建了一个新实例来表示三倍表。通过将值传递3给结构的initializer值作为实例multiplier参数的值来表明这一点

    您可以threeTimesTable通过调用实例的下标来查询实例,如对的调用所示threeTimesTable[6]这将请求三倍表中的第六个条目,该表返回值为183times 6

    注意

    一个ñ -times表是基于一个固定的数学规则。设置threeTimesTable[someIndex]新值是不合适的,因此for的下标TimesTable定义为只读下标。

    下标用法

    “下标”的确切含义取决于使用它的上下文。下标通常用作访问集合,列表或序列中的成员元素的快捷方式。您可以根据自己的特定类或结构的功能,以最合适的方式自由实现下标。

    例如,Swift的Dictionary类型实现了下标来设置和检索Dictionary实例中存储的值您可以在字典中设置值,方法是在下标括号内提供字典的键类型的键,然后将字典的值类型的值分配给下标:

    1. var numberOfLegs = ["spider": 8, "ant": 6, "cat": 4]
    2. numberOfLegs["bird"] = 2

    上面的示例定义了一个名为的变量numberOfLegs,并使用包含三个键值对的字典文字对其进行了初始化。numberOfLegs字典的类型推断为创建字典后,本示例使用下标分配向字典添加[String: Int]String"bird"Int2

    有关Dictionary下标的更多信息,请参见访问和修改字典

    注意

    Swift的Dictionary类型将其键值下标实现为采用并返回可选类型的下标对于numberOfLegs上面字典,键值下标接受并返回type Int?或“ optional int”的值。Dictionary类型使用可选的下标类型来建模并非每个键都具有值的事实,并提供一种通过为该键分配nil来删除该键的值的方法。

    下标选项

    下标可以采用任意数量的输入参数,并且这些输入参数可以是任何类型。下标还可以返回任何类型的值。

    像函数一样,下标可以采用不同数量的参数,并为其参数提供默认值,如可变参数默认参数值中所述但是,与函数不同,下标不能使用输入输出参数。

    一个类或结构可以根据需要提供尽可能多的下标实现,并且将根据使用下标时在下标括号中包含的一个或多个值的类型来推断要使用的适当下标。多个下标的定义称为下标重载

    虽然下标采用单个参数是最常见的,但是如果适合您的类型,则还可以定义带有多个参数的下标。下面的示例定义一个Matrix结构,该结构表示Double的二维矩阵Matrix结构的标有两个整型参数:

    1. struct Matrix {
    2. let rows: Int, columns: Int
    3. var grid: [Double]
    4. init(rows: Int, columns: Int) {
    5. self.rows = rows
    6. self.columns = columns
    7. grid = Array(repeating: 0.0, count: rows * columns)
    8. }
    9. func indexIsValid(row: Int, column: Int) -> Bool {
    10. return row >= 0 && row < rows && column >= 0 && column < columns
    11. }
    12. subscript(row: Int, column: Int) -> Double {
    13. get {
    14. assert(indexIsValid(row: row, column: column), "Index out of range")
    15. return grid[(row * columns) + column]
    16. }
    17. set {
    18. assert(indexIsValid(row: row, column: column), "Index out of range")
    19. grid[(row * columns) + column] = newValue
    20. }
    21. }
    22. }

    Matrix提供一个初始化器,该初始化器带有两个称为rows和的参数columns,并创建一个足以存储type值的数组矩阵中的每个位置的初始值均为为此,将数组的大小和初始单元格值传递给数组初始化程序,该初始化程序创建并初始化正确大小的新数组。使用默认值创建数组中将详细描述此初始化程序rows columnsDouble0.00.0

    您可以Matrix通过将适当的行数和列数传递给其初始化程序来构造新实例:

    1. var matrix = Matrix(rows: 2, columns: 2)

    上面的示例创建一个Matrix具有两行两列的新实例。实例grid数组Matrix实际上是矩阵的展平版本,从左上角到右下角读取:

    ../_images/subscriptMatrix01_2x.png

    可以通过将行和列值传递到下标(以逗号分隔)来设置矩阵中的值:

    1. matrix[0, 1] = 1.5
    2. matrix[1, 0] = 3.2

    这两个语句调用标的setter设置的值1.5在矩阵(其中右上角的位置row0column1),并3.2在左下角位置(row1column0):

    ../_images/subscriptMatrix02_2x.png

    Matrix标的getter和setter都包含一个断言,以检查标的rowcolumn值是有效的。为了帮助进行这些声明,Matrix包括一个名为的便捷方法indexIsValid(row:column:),该方法检查请求的rowcolumn是否在矩阵的边界内:

    1. func indexIsValid(row: Int, column: Int) -> Bool {
    2. return row >= 0 && row < rows && column >= 0 && column < columns
    3. }

    如果您尝试访问矩阵边界之外的下标,则会触发一个断言:

    1. let someValue = matrix[2, 2]
    2. // This triggers an assert, because [2, 2] is outside of the matrix bounds.

    类型下标

    如上所述,实例下标是您在特定类型的实例上调用的下标。您还可以定义在类型本身上调用的下标。这种下标称为类型下标您可以通过在static关键字之前写入关键字来指示类型下标subscript类可以改用class关键字,以允许子类覆盖该下标的超类实现。以下示例显示了如何定义和调用类型下标:

    1. enum Planet: Int {
    2. case mercury = 1, venus, earth, mars, jupiter, saturn, uranus, neptune
    3. static subscript(n: Int) -> Planet {
    4. return Planet(rawValue: n)!
    5. }
    6. }
    7. let mars = Planet[4]
    8. print(mars)
  • 相关阅读:
    第八篇:Vue组件传参
    第七篇:Vue的路由逻辑跳转
    第六篇:组件数据局部化处理
    第五篇:Vue项目的初始化
    第四篇:Vue的项目开发
    第三篇:Vue指令
    第二篇:Vue实例成员
    第一篇:Vue基础
    第六篇:js对象,类和函数补充
    AngularJS之jeDate日期控件基本使用
  • 原文地址:https://www.cnblogs.com/strengthen/p/9739175.html
Copyright © 2020-2023  润新知