Swift教程之下标

下标

类、结构体和枚举可以定义下标,它们是访问集合、列表或序列的成员元素的快捷方式。可以使用下标通过索引设置和检索值,而不需要单独的设置和检索方法。

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


## 下标语法 下标语法类似于实例方法和计算型属性语法,使用**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
posted @ 2017-10-04 17:22  chipsKe  阅读(263)  评论(0编辑  收藏  举报