下标
类、结构体和枚举可以定义下标,它们是访问集合、列表或序列的成员元素的快捷方式。可以使用下标通过索引设置和检索值,而不需要单独的设置和检索方法。
可以为多个类型定义下标,并根据传递给下标的索引值的类型来选择要使用的适当的下标重载。下标不限于单个维度,可以使用多个输入参数定义下标以满足自定义类型的需求。
## 下标语法 下标语法类似于实例方法和计算型属性语法,使用**subscript**关键字编写下标定义,并以与实例方法相同的方式指定一个或多个输入参数和返回类型。与实例方法不同,下标可以是读写或只读。
subscript(index: Int) -> Int {
get {
// return an appropriate subscript value here
}
set(newValue) {
// perform a suitable setting action here
}
}
newValue的类型与下标的返回值相同,可以自定setter的参数名称。
只读下标语法:
subscript(index: Int) -> Int {
// return an appropriate subscript value here
}
以下是一个只读下标实现的例子:
struct TimesTable {
let multiplier: Int
subscript(index: Int) -> Int {
return multiplier * index
}
}
let threeTimesTable = TimesTable(multiplier: 3)
print("six times three is (threeTimesTable[6])")
// Prints "six times three is 18"
## 下标选项 下标可以使用任意数量的任何类型的可变参数,也可以返回任何类型。下标可以使用可变参数,但不能使用**in-out**参数或设置默认参数值。
下标通常使用单个参数,也可以使用多个参数来定义下标以适用类型。
下面声明一个具有下标的Matrix结构体,通过行、列数初始化一个元素全为0的二维矩阵,使用下标可获取并设置矩阵中某行某列的值。
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
let someValue = matrix[2, 2]
// this triggers an assert, because [2, 2] is outside of the matrix bounds