为了防止潜在的崩溃,每当我尝试访问阵列中的特定元素时,我通常会进行一些安全检查.我才意识到我已经厌倦了这样做.有没有办法快速安全地完成?
var array:[String] = [/*Filled with stuff*/]
func someFunc(someIndex:Int){
//This is unsafe. It will crash if index is negative or larger than count.
let text = array[someIndex]
//This is completely safe, but boring.
let text:String
if someIndex >= 0 && someIndex < array.count{
text = array[someIndex]
}else { return }
//What I want is something like this:
let text = array.hasElement(at: someIndex) ? array[someIndex] : return
//I know, I can't really put a 'return' in a statement like this, but I really want to..
//Optimally, I'd like something like this:
guard let text = array[someIndex] else { return }
//But this is illegal because it's not an conditional binding with an optional type.
}
Run Code Online (Sandbox Code Playgroud)
写这篇文章的时候,我意识到我可以创建自己的扩展Sequence或其他东西,为其添加一个函数func hasElement(at:Int)->Bool.但我宁愿想要一种方法来使用,guard因为我不能做内联condition ? true : return..
任何一行都很受欢迎..
很简单,可以使用扩展名Collection:
extension Collection {
subscript(checked index: Index) -> Element? {
if self.indices.contains(index) {
return self[index]
} else {
return nil
}
}
}
Run Code Online (Sandbox Code Playgroud)
所以:
let arr = ["Foo", "Bar", "Baz"]
print(arr[checked: 2]) // Optional("Baz")
print(arr[checked: 3]) // nil
Run Code Online (Sandbox Code Playgroud)
如果那太多了,你可以使用三元运算符:
let foo: String? = arr.indices.contains(3) ? arr[3] : nil
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
84 次 |
| 最近记录: |