《swift2.0 官方教程中文版》 第2章-12下标脚本

《swift2.0 官方教程中文版》 第2章-12下标脚本,第1张

概述import Foundation //用下标脚本访问一个数组(Array)实例中的元素可以这样写 so meArray[index] ,访问字典(Dictionary)实例中的元素可以这样写 someDictionary[key] 。 /*下标脚本语法******************************************************/ //下标脚本允许你通过在实例后面的


import Foundation


//用下标脚本访问一个数组(Array)实例中的元素可以这样写 so meArray[index],访问字典(Dictionary)实例中的元素可以这样写 someDictionary[key]


/*下标脚本语法******************************************************/

//下标脚本允许你通过在实例后面的方括号中传入一个或者多个的索引值来对实例进行访问和赋值

//subscript(index: Int) -> Int {

// get {

// // 返回与入参匹配的Int类型的值

// }

//

// set(newValue) {

// // 执行赋值 *** 作返回与入参匹配的Int类型的值

// }

//}


//subscript(index: Int) -> Int {

// // 返回与入参匹配的Int类型的值

//}


struct Timestable {

let multiplIEr: Int

subscript(index: Int) -> Int {

return multiplIEr * index

}

}

let threeTimestable = Timestable(multiplIEr: 3)

print("36倍是\(threeTimestable[6])")

// 输出 "36倍是18"

//Timestable 例子是基于一个固定的数学公式。它并不适合对 threeTimestable[someIndex] 进行赋值 *** 作,这也是为什么附属脚本只定义为只读的原因。




/*下标脚本用法******************************************************/

//根据使用场景不同下标脚本也具有不同的含义。通常下标脚本是用来访问集合(collection),列表(List)或序 (sequence)中元素的快捷方式。你可以在你自己特定的类或结构体中自由的实现下标脚本来提供合适的功能。

var numberOfLegs = ["spIDer": 8,"ant": 6,"cat": 4]

numberOfLegs["bird"] = 2


//Swift 中字典的附属脚本实现中, get 部分返回值是 Int?,上例中的 numberOfLegs 字典通过附属脚本返 回的是一个 Int? 或者说可选的int”,不是每个字典的索引都能得到一个整型值,对于没有设过值的索引的访 问返回的结果就是 nil ;同样想要从字典实例中删除某个索引下的值也只需要给这个索引赋值为 nil 即可。

numberOfLegs["spIDer"] = nil

print(numberOfLegs)




/*下标脚本选项******************************************************/

//下标脚本允许任意数量的入参索引,并且每个入参类型也没有限制。下标脚本的返回值也可以是任何类型。下标 脚本可以使用变量参数和可变参数,但使用写入读出(in-out)参数或给参数设置默认值都是不允许的。

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,"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]

// 断言将会触发,因为 [2,2] 已经超过了matrix的最大长度

总结

以上是内存溢出为你收集整理的《swift2.0 官方教程中文版》 第2章-12下标脚本全部内容,希望文章能够帮你解决《swift2.0 官方教程中文版》 第2章-12下标脚本所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1082211.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存