Swift语法基础:10 - Swift的布尔值, 元组, 可选, 断言

在前面, 我们学了关于数据类型的一些知识, 还有一个别名的定义方式, 好了, 废话少说, 让我们来看看:


1.布尔值

let orangesAreOrange = true
let turnipsAreDelicious = false

if orangesAreOrange {
    println("Mmm, tasty turnips!")
} else {
    println("Eww, turnips are horrible.")
}
// 打印出来的结果: Mmm, tasty turnips!

在使用Bool的时候, 我们可以使用if来控制.

在这里我们需要对if补充点东西, 在Swift使用if的时候, 我们需要声明条件, 否则编译器就会报错:

错误例子:

let a = 1
if a {
}
// 报错: Type 'Int' does not conform to protocol 'BooleanType'

正确的例子:

let a = 1
if a == 1{

}

2.元组

在Swift中, 有一个不同于OC中的数组, 但又有一些类似, 下面让我们来看看例子:

let http404Error = (404, "Not Found")

let (statusCode, statusMessage) = http404Error
println("The status code is \(statusCode)")
// 打印出来的结果: The status code is 404
println("The status message is \(statusMessage)")
// 打印出来的结果: The status message is Not Found

元组不同于数组的是, 它可以有多种类型, 也可以把多个值组合成一个复合值, 而数组是单一的类型, 不可以存储多种类型的东西.

还有一个更加强大的是, 你可以选择元组中的某个部分, 也可以去掉某个部分, 比如:

let (justTheStatusCode, _) = http404Error
println("The status code is \(justTheStatusCode)")
// 打印出来的结果: The status code is 404

也可以利用元组中的某个元件来进行打印, 比如:

println("The status code is \(http404Error.0)")
// 打印出来的结果: The status code is 404
println("The status message is \(http404Error.1)")
// 打印出来的结果: The status message is Not Found

也可以在声明元组的时候给元组里面的元件定义一些别名, 比如:

let http200Status = (statusCode: 200, description: "OK")
println("The status code is \(http200Status.statusCode)")
// 打印出来的结果: The status code is 200
println("The status message is \(http200Status.description)")
// 打印出来的结果: The status message is OK

这个也是数组不所具备的特性, 虽然元组是比数组好用, 但在开发中, 我们也不能滥用元组, 适合才是王道.


3.可选

在Swift中, 有一个新的特性, 叫做optionals(可选), 举个例子, x声明时加上可选, 那么这个x就会有两种情况, 一种就是有值就等x 或者是没有值, 返回一个nil, 这与OC中的逻辑有一定的出入, 因为OC中它是要明确的声明该变量是否有没有值, 而且就算你要声明为nil, 你也要有明确的对象.

let possibleNumber = "123"
let convertedNumber = possibleNumber.toInt()
println(convertedNumber)
// 打印出来的结果: Optional(123)

在这个例子中, 我们给possjbleNumber初始化的时候声明了是String类型的, 但是在我们使用的时候, 加上toInt(), 一个是Srting类型, 一个是Int类型, 虽然类型不匹配, 但编译器不会直接报错, 但是它会有一个可选的提示, 可以选择把这个字符串转成Int类型.

那么我们怎样把这个可选变成肯定的值呢, 我们要在调用的时候加上一个 ‘!’ 号才可以, 比如:

if (convertedNumber != nil) {
    println("\(possibleNumber) has an integer value of \(convertedNumber!)")
} else {
    println("\(possibleNumber) could not be converted to an integer")
}
// 输出来的结果: 123 has an integer value of 123

PS: 在使用 ‘!’ 号的时候, 一定要清楚的知道该值是否是非nil, 否则的话就会出错.


4.可选绑定

可选绑定是用来判断可选是否包含值, 如果包含就把值赋给临时变量或者常量.

if let actualNumber = possibleNumber.toInt() {
    println("\(possibleNumber) has an integer value of \(actualNumber)")
} else {
    println("\(possibleNumber) could not be converted to an integer")
}
// 打印出来的结果: 123 has an integer value of 123

看例子, 我们知道是转型成功, 并且可以输出了正确的值, 这段代码的意思就是, 如果possjbleNumber.toInt转型成功, 那么我们就把值赋给常量actualNumber, 然后在输出成功转型的值, 否则就输出转型不成功的值.


5.nil

在Swift中的nil, 与OC中类似, 但又多了一些特征, 下面让我们来看看:

var serverResponseCode: Int? = 404
// serverResponseCode 包含了一个可选的Intz值 404
serverResponseCode = nil
// serverResponseCode 现在不包含值

PS: nil不能用在非可选的常量或者变量当中, 如果在代码中有常量或者变量缺失


6.隐式解析可选

在我们Swfit中, 如果确定一个变量总会有值的话, 我们就不能经常用 ‘?’ 号, 因为这样子就会增加运算, 效率会非常的低, 在这里我们要使用一个隐式可选.

常规的可选:

let possibleString: String? = "An optional string."
println(possibleString!)
// 打印出来的结果: An optional string.

由于possibleString在初始化之后就总会有值, 所以我们在这里进行一些修改:

let assumedString: String! = "An implicitly unwrapped optional string."
println(assumedString) // 在这里是不需要再加 '!'
// 打印出来的结果: An implicitly unwrapped optional string.

只要在声明的时候加上一个 ‘!’ 号, 那么就说明你定义的常量就必须得要有值, 不需要在内部再使用 if 进行判断, 这个可以提高我们的执行效率.
PS: 如果你在隐式解析可选没有值的时候尝试取值, 会触发运行时的错误.

但是在新更新的Swift中, 使用隐式可选的常量或者变量, 再使用时, 得加上那么一句代码:

if (assumedString != nil) {
    println(assumedString)
}
// 打印出来的结果: An implicitly unwrapped optional string.    

在这里, 可以括号括起来, 也可以不用括号, 都是可以的:

if assumedString != nil {
    println(assumedString)
}
// 打印出来的结果: An implicitly unwrapped optional string.

同样, 也是可以这么使用:


if let definiteString = assumedString {
    println(definiteString)
}
// 打印出来的结果: An implicitly unwrapped optional string.

7.断言

在我们程序开发的时候, 我们有一项非常重要的工作, 那就是调试, 在Swift的可选中, 可以判断该值是否存在, 如果该值存在, 那么程序就会正常运行, 但如果该值不存在, 那么程序就会中止, 这里面有一个全局的函数叫做assertion, 我们可以通过传入一个值, 然后去判断该值是否满足条件, 如果是turn那就正常运行, 如果是false, 那就中止, 比如:

let age = -3
assert(age >= 0, "A person's age cannot be less than zero")

断言
这样子就会触发断言, 因为不符合我们所要求的, 所以就会中止程序.

并且断言有一个要求, 在断言里面是不能插入字符串信息的, 所以我们这里需要改进一下:

assert(age >= 0)

使用断言的场景:
1.整数的附属脚本索引被传入一个自定义附属脚本实现,但是下标索引值可能太小或者太大。

2.需要给函数传入一个值,但是非法的值可能导致函数不能正常执行。

3.一个可选值现在是 nil,但是后面的代码运行需要一个非 nil 值。

PS: 断言的出现是会让程序中止的, 所以在这里我们需要仔细设计代码来让非法条件不会出现.


好了, 这次我们就讲到这里, 下次我们继续~~~

posted @   背着吉他去流浪  阅读(268)  评论(0编辑  收藏  举报
编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· 《HelloGitHub》第 106 期
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
点击右上角即可分享
微信分享提示