The Swift Programming Language学习笔记(十三)——下标
下标下标(subscripts)可以定义在类(class)、结构体(structure)和枚举(enumeration)中,是访问集合(collection),列表(list)或序列(sequence)中元素的快捷方式。可以使用下标的索引,设置和获取值,而不需要再调用对应的存取方法。举例来说,用下标访问一个 一个类型可以定义多个下标,通过不同索引类型进行 下标语法下标允许你通过在实例名称后面的方括号中传入一个或者多个索引值来对实例进行存取。语法类似于实例方法语法和计算型属性语法的混合。与定义实例方法类似,定义下标使用 如同计算型属性,可以不指定 如同只读计算型属性,可以省略只读下标的 /** * 乘法表,基于数学公式,设置为只读。 */
struct TimesTable {
let multiplier: Int
subscript(index: Int) -> Int {
return index * multiplier
}
}
let t = TimesTable(multiplier: 5)
print(t[2]) // 10
print(t[100]) // 500
下标用法下标的确切含义取决于使用场景。下标通常作为访问集合(collection),列表(list)或序列(sequence)中元素的快捷方式。你可以针对自己特定的类或结构体的功能来自由地以最恰当的方式实现下标。例如,Swift的 Swift的 下标选项下标可以接受任意数量的入参,并且这些入参可以是任意类型。下标的返回值也可以是任意类型。下标可以使用变量参数和可变参数,但不能使用输入输出参数,也不能给参数设置默认值。 一个类或结构体可以根据自身需要提供多个下标实现,使用下标时将通过入参的数量和类型进行区分,自动匹配合适的下标,这就是下标的 struct Matrix {
let rows: Int,colnums: Int
var grid: [Double] = []
init(rows: Int,colnums: Int) {
self.rows = rows
self.colnums = colnums
self.grid = Array(count: rows * colnums,repeatedValue: 0.0)
}
func indexIsValidForRow(row: Int,colnum: Int) -> Bool {
return row >= 0 && row < rows && colnum >= 0 && colnum < colnums
}
subscript(row: Int,colnum: Int) -> Double {
get {
assert(indexIsValidForRow(row,colnum: colnum),"Index out of range")
return grid[row * colnums + colnum]
}
set {
assert(indexIsValidForRow(row,"Index out of range")
grid[row * colnums + colnum] = newValue
}
}
}
var m = Matrix(rows: 3,colnums: 4)
print(m) // Matrix(rows: 3,colnums: 4,grid: [0.0,0.0,0.0])
m[0,3] = 100.0
m[1,2] = 98.5
print(m) // Matrix(rows: 3,100.0,98.5,0.0])
// print(m[3,3]) // assertion failed: Index out of range: file <EXPR>,line 17
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |