对照Java学习Swift--下标(Subscripts)
2016-05-05 00:48
561 查看
Java中限制了下标的操作,只有在数组中才能使用,非常简单,但是在Swift中,可以在类(class)、结构体(structure)和枚举(enumeration)中,是访问集合(collection),列表(list)或序列(sequence)中元素的快捷方式。
newValue的类型和下标的返回类型相同。如同计算型属性,可以不指定 setter 的参数(newValue)。如果不指定参数,setter 会提供一个名为newValue的默认参数。
如同只读计算型属性,可以省略只读下标的get关键字:
我们来看一个例子:
这个例子是只读的下标表达式。
数组的用法:
一个类或结构体可以根据自身需要提供多个下标实现,使用下标时将通过入参的数量和类型进行区分,自动匹配合适的下标,这就是下标的重载。
下面我们看一个例子:
使用如下:
Matrix下标的 getter 和 setter 中都含有断言,用来检查下标入参row和column的值是否有效。为了方便进行断言,Matrix包含了一个名为indexIsValidForRow(_:column:)的便利方法,用来检查入参row和column的值是否在矩阵范围内。
如果下标越界将触发断言:
所以说越界是不允许的。
下标语法
下标允许你通过在实例名称后面的方括号中传入一个或者多个索引值来对实例进行存取。语法类似于实例方法语法和计算型属性语法的混合。与定义实例方法类似,定义下标使用subscript关键字,指定一个或多个输入参数和返回类型;与实例方法不同的是,下标可以设定为读写或只读。这种行为由 getter 和 setter 实现,有点类似计算型属性:subscript(index: Int) -> Int { get { // 返回一个适当的 Int 类型的值 } set(newValue) { // 执行适当的赋值操作 } }
newValue的类型和下标的返回类型相同。如同计算型属性,可以不指定 setter 的参数(newValue)。如果不指定参数,setter 会提供一个名为newValue的默认参数。
如同只读计算型属性,可以省略只读下标的get关键字:
subscript(index: Int) -> Int { // 返回一个适当的 Int 类型的值 }
我们来看一个例子:
struct TimesTable { let multiplier:Int subscript(index: Int) -> Int{ return multiplier * index } } let threeTimesTable = TimesTable(multiplier: 3) print("six times three is \(threeTimesTable[6])")
这个例子是只读的下标表达式。
下标用法
字典的用法:var numberOfLegs = ["spider": 8, "ant": 6, "cat": 4] numberOfLegs["bird"] = 2
数组的用法:
var numberOfLegs = ["spider", "ant", "cat"] print(numberOfLegs[0])
下标选项
下标可以接受任意数量的入参,并且这些入参可以是任意类型。下标的返回值也可以是任意类型。下标可以使用变量参数和可变参数,但不能使用输入输出参数,也不能给参数设置默认值。一个类或结构体可以根据自身需要提供多个下标实现,使用下标时将通过入参的数量和类型进行区分,自动匹配合适的下标,这就是下标的重载。
下面我们看一个例子:
struct Matrix { let rows:Int,columns:Int var grid:[Double] init(rows:Int,columns:Int){ self.rows = rows self.columns = columns grid = Array(count: rows*columns, repeatedValue: 0.0) } func indexIsValidForRow(row:Int,column:Int) -> Bool{ return row >= 0 && row < rows && column >= 0 && column < columns } subscript(row:Int,column:Int) -> Double{ get{ assert(indexIsValidForRow(row, column: column),"Index Out of range") return grid[(row*columns) + column] } set{ assert(indexIsValidForRow(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
Matrix下标的 getter 和 setter 中都含有断言,用来检查下标入参row和column的值是否有效。为了方便进行断言,Matrix包含了一个名为indexIsValidForRow(_:column:)的便利方法,用来检查入参row和column的值是否在矩阵范围内。
如果下标越界将触发断言:
let someValue = matrix[2, 2]
所以说越界是不允许的。
相关文章推荐
- Swift中的分类
- Swift中TextField
- Swift解读专题一——Swift2.2语言预览
- Swift 仿简书、淘宝App的弹出view效果
- swift 基本语法(二)
- Swift开发:Swift项目调用OC代码
- swift闭包
- IOS8中SWIFT 弹出框的显示
- Swift 中 10 个震惊小伙伴的单行代码
- Swift2.x编写NavigationController动态缩放titleView
- Swift 中的内存管理详解
- NSHelper.showAlertTitle的两种用法 swift
- Swift开发:NSLayoutConstraint纯代码实现自动布局-初级篇
- swift -UITextField
- swift 使用UIButton
- swift语言UILabel的使用
- Swift 中枚举高级用法及实践
- swift学习笔记(一)基本数据类型(下)
- Swift使用友盟分享
- [swift学习之二]基本语法练习