Swift

下标

本文详细介绍了 Swift 中的下标,包括下标语法、下标用法、下标选项以及类型下标。

下标(Subscripts)可以定义在类、结构体和枚举中,是访问集合、列表或序列中元素的快捷方式。使用下标的索引,设置和获取值时不需要调用专门的设置和获取方法。

下标语法

下标允许你通过在实例名称后面的方括号中传入一个或多个索引值来对实例进行查询。语法类似于实例方法语法和计算属性语法的混合。

使用 subscript 关键字定义下标:

subscript(index: Int) -> Int {
    get {
        // 返回一个适当的 Int 类型的值
    }
    set(newValue) {
        // 执行适当的赋值操作
    }
}

如果是只读下标,可以省略 get 关键字:

struct TimesTable {
    let multiplier: Int
    subscript(index: Int) -> Int {
        return multiplier * index
    }
}

let threeTimesTable = TimesTable(multiplier: 3)
print("six times three is \(threeTimesTable[6])")
// 打印 "six times three is 18"

下标用法

下标的确切含义取决于使用它的上下文。通常用于作为集合元素的快捷访问方式。

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

在这个例子中,字典 numberOfLegs 通过下标赋值来添加一个新的键值对。

下标选项

下标可以接受任意数量的输入参数,并且这些参数可以是任意类型。下标的返回值也可以是任意类型。

多参数下标

下标可以定义多个参数。

struct Matrix {
    let rows: Int, columns: Int
    var grid: [Double]
    
    init(rows: Int, columns: Int) {
        self.rows = rows
        self.columns = columns
        grid = Array(repeating: 0.0, count: rows * columns)
    }
    
    func indexIsValid(row: Int, column: Int) -> Bool {
        return row >= 0 && row < rows && column >= 0 && column < columns
    }
    
    subscript(row: Int, column: Int) -> Double {
        get {
            assert(indexIsValid(row: row, column: column), "Index out of range")
            return grid[(row * columns) + column]
        }
        set {
            assert(indexIsValid(row: row, column: column), "Index out of range")
            grid[(row * columns) + column] = newValue
        }
    }
}

var matrix = Matrix(rows: 2, columns: 2)
matrix[0, 1] = 1.5
matrix[1, 0] = 3.2

类型下标

正如可以定义类型属性和类型方法一样,也可以定义类型下标。类型下标属于类型本身,而不是类型的实例。

使用 static 关键字定义类型下标。类可以使用 class 关键字允许子类重写。

enum Planet: Int {
    case mercury = 1, venus, earth, mars, jupiter, saturn, uranus, neptune
    static subscript(n: Int) -> Planet {
        return Planet(rawValue: n)!
    }
}

let mars = Planet[4]
print(mars)
在 GitHub 上编辑

上次更新于