Swift基础语法 - 可选项
创始人
2024-05-26 04:43:33
0

可选项(Optional)

  • 可选项,一般也叫可选类型,它允许将值设置为 nil
  • 在类型名称后面加个问号 ? 来定义一个可选项
var name: String? = "CSDN"
name = nilvar age: Int? //默认就是nil
age = 30
age = nil

在这里插入图片描述

var array = [2, 4, 6, 8]func getNumber(_ index: Int) -> Int? {if index < 0 || index >= array.count {return nil}return array[index]
}print(getNumber(1)) //Optional(4)
print(getNumber(-1)) //nil
print(getNumber(4)) //nil

在这里插入图片描述

强制解包(Forced Unwrapping)

  • 可选项是对其他类型的一层包装,可以将它理解为一个盒子
  • 如果为 nil ,那么它是个空盒子
  • 如果不为 nil ,那么盒子里装的是:被包装类型的数据
var age: Int? //默认就是nil
age = 10
age = nil

在这里插入图片描述

  • 如果要从可选项中取出被包装的数据(将盒子里装的东西取出来),需要使用 感叹号 ! 进行强制解包
var age: Int? = 20let ageInt: Int = age!print(ageInt) //20

在这里插入图片描述

  • 如果对值为 nil 的可选项(空盒子)进行强制解包,将会产生运行时错误
var age: Int?
age!

在这里插入图片描述

Fatal error: Unexpectedly found nil while unwrapping an Optional value

判断可选项是否包含值

let number = Int("123")if number != nil {print("字符串转成数字成功为:\(number!)")
}else{print("字符串转成数字失败")
}
// 字符串转成数字成功为:123

可选项绑定(Optional Binding)

  • 可以使用 可选绑定 来判断可选项是否包含值
  • 如果包含就自动解包,把赋值给一个临时的常量( let )或者变量( var ),并返回 true ,否则返回 false
if let number = Int("123") {print("字符串转成数字成功为:\(number)")// number 是强制解包之后的Int值// number 作用域仅限于这个大括号
}else{print("字符串转成数字失败")
}
// 字符串转成数字成功为:123
enum Season : Int {case spring = 1, summer, autumn, winter
}if let season = Season(rawValue: 8){switch season {case .spring:print("the season is spring")default:print("the season is other")}
} else {print("no such season")
}
// no such season

等价写法

if let first = Int("5") {if let second = Int("45") {if first < second && second < 50 {print("\(first) < \(second) < 50")}}
}
// 5 < 45 < 50if let first = Int("5"),let second = Int("45"),first < second && second < 50 {print("\(first) < \(second) < 50")
}
// 5 < 45 < 50

while 循环中使用可选项绑定

//遍历数组,将遇到 的正整数都加起来,如果遇到负数或者非数字,则停止遍历
var array = ["10", "20", "30", "ab", "-20", "40"]var index = 0
var sum = 0
while let num = Int(array[index]), num > 0 {sum += numindex += 1
}
print(sum)

空合并运算符 ?? (Nil - Coalescing Operator)

public func ?? (optional: T?, defaultValue: @autoclosure () throws -> T?) rethrows -> T?
public func ?? (optional: T?, defaultValue: @autoclosure () throws -> T) rethrows -> T
  • a ?? b
  • a 是可选项
  • b 是可选项 或者 不是可选项
  • ba 的存储类型必须相同
  • 如果 a 不为 nil ,就返回 a
  • 如果 a nil ,就返回 b
  • 如果 b 不是可选项,返回 a 时会自动解包
let a: Int? = 1
let b: Int? = 2
let c = a ?? b // c是Int? , Optional(1)
let a: Int? = nil
let b: Int? = 2
let c = a ?? b // c是Int? , Optional(2)
let a: Int? = nil
let b: Int? = nil
let c = a ?? b // c是Int? , nil
let a: Int? = 1
let b: Int = 2
let c = a ?? b // c是Int , 1
let a: Int? = nil
let b: Int = 2
let c = a ?? b // c是Int , 2
let a: Int? = nil
let b: Int = 2
//如果不使用 ?? 运算符
let c: Int
if let tmp = a {c = tmp
} else {c = b
}

多个 ?? 一起使用

let a: Int? = 1
let b: Int? = 2
let c = a ?? b ?? 3 // c是Int , 1
let a: Int? = nil
let b: Int? = 2
let c = a ?? b ?? 3 // c是Int , 2
let a: Int? = nil
let b: Int? = nil
let c = a ?? b ?? 3 // c是Int , 3

?? 跟 if let 配合使用

let a: Int? = nil
let b: Int? = 2
if let c = a ?? b {print(c)
}
//类似于 if a != nil || b != nil
let a: Int? = nil
let b: Int? = 2
if let c = a , let d = b {print(c)print(d)
}
// 类似于 if a != nil && b != nil

if 语句实现登录

func login(_ info: [String : String]) {let username: Stringif let tmp = info["username"] {username = tmp} else {print("请输入用户名")return}let password: Stringif let tmp = info["password"] {password = tmp} else {print("请输入密码")return}// if username ....// if password ....print("用户名:\(username)", "密码:\(password)", "登陆ing")
}
login(["username" : "jack", "password" : "123456"]) // 用户名:jack 密码:123456 登陆ing
login(["password" : "123456"]) // 请输入密码
login(["username" : "jack"]) // 请输入用户名

guard 语句

guard 条件 else {// do something....退出当前作用域//return、break、continue、throw error
}
  • guard 语句的条件为 false 时,就会执行大括号里面的代码
  • guard 语句的条件为true时,就会跳过 guard 语句
  • guard 语句特别适合用来“提前退出”
  • 当使用 guard 语句进行可选项绑定时,绑定的常量( let )、变量( var )也能在外层作用域中使用
func login(_ info: [String : String]){guard let username = info["username"] else {print("请输入用户名")return}guard let password = info["password"] else {print("请输入密码")return}// if username ...// if password ...print("用户名:\(username)","密码:\(password)","登录ing")
}
login(["username" : "jack", "password" : "123456"]) // 用户名:jack 密码:123456 登陆ing
login(["password" : "123456"]) // 请输入密码
login(["username" : "jack"]) // 请输入用户名

隐式解包(Implicitly Unwrapped Optional)

  • 在某些情况下,可选项一旦被设定值之后,就会一直拥有值
  • 在这种情况下,可以去掉检查,也不必每次访问的时候都进行解包,因为它能确定每次访问的时候都有值
  • 可以在类型后面加个感叹号 !定义一个隐式解包的可选项
let num1: Int! = 10
let num2: Int = num1
if num1 != nil {print(num1 + 6) // 16
}
if let num3 = num1 {print(num3) // 10
}
let num1: Int! = nil
//Fatal error: Unexpectedly found nil while implicitly unwrapping an Optional value
let num2: Int = num1

在这里插入图片描述

字符串插值

  • 可选项在字符串插值或直接打印时,编译器会发出警告
var age: Int? = 10
print("My age is \(age)")

在这里插入图片描述

  • 至少有3种方法消除警告
print("My age is \(age!)")
//My age is 10print("My age is \(String(describing: age))")
//My age is Optional(10)print("My age is \(age ?? 0)")
//My age is 10

多重可选项

var num1: Int? = 10
var num2: Int?? = num1
var num3: Int?? = 10print(num2 == num3) // true
  • 可以使用lldb指令 frame variable –R 或者 fr v –R 查看区别
var num1: Int? = nil
var num2: Int?? = num1
var num3: Int?? = nilprint(num2 == num3) // false(num2 ?? 1) ?? 2 // 2
(num3 ?? 1) ?? 2 // 1

相关内容

热门资讯

为中国式现代化贡献法治力量 2023年2月7日,在上海虹桥街道古北市民中心召开的立法意见征询会后,盛弘(右一)和参会代表交流。新...
打造乡村振兴人才新引擎 本报西宁讯 (记者 李延平) 3月5日,西宁乡村振兴学院揭牌成立仪式暨首期乡镇干部培训班开班式举行,...
数字为媒,提升文旅新业态含“智... □ 本报记者 王诗宇 曹凯琪 3月5日,习近平总书记参加他所在的十四届全国人大三次会议江苏代表...
聚力“重特大”,推动城市能级跃... 全国人大代表,淮安市委常委、常务副市长 林小明 全国人大代表、国网江苏省电力有限公司金湖县供电...
链动未来 智创标杆 向新而行 江南农村商业银行始终坚守定位,回归主责主业,立足本地本源,坚持做小做散做优,以金融“五篇大文章”为主...
北京市政协2025年将推动“京... 转自:千龙网3月7日晚,全国政协委员、北京市政协主席魏小东接受媒体集体采访,围绕北京市政协履职情况和...
宜兴加快建设以科技创新为引领的... 党的十八大以来,习近平总书记把创新摆在国家发展全局的核心位置,高度重视科技创新,不断强调科技创新在全...
坚持高水平协同联动 张国梁 □ 新华日报记者 姚政宇 “推动长江经济带高质量发展,江苏在多个方面下了‘狠功...
全国政协十四届常委会 第十一次... 新华社北京3月9日电  政协第十四届全国委员会常务委员会第十一次会议9日下午在北京举行。中共中央政治...
这场爱心接力,“跑”了40多年 近日,梅园新村街道太平门社区新时代学雷锋实践站志愿者与驻宁某部三连官兵组团,再次走进蒋高银家中,擦玻...
创新赋能 扬优成势 向“新”提“质”,以“质”催“新”。生产力是推动经济增长的决定性因素。在全国两会上,贠红卫代表说,我...
老北桥有了“新”味道 无锡市滨湖区河埒街道北桥社区为典型的混合型社区,辖区内业态复杂、老旧小区居多。在城市更新的浪潮中,一...
长三角“民营经济”,百尺竿头再... □ 本报记者 王建朋 从中央召开的民营企业座谈会,到全国两会热议促进民营经济发展,民营经济成为...
2000个岗位“栖”待“宁”来 本报讯 (王丽华 彭蓉) 3月5日下午,南京市暨栖霞区2025年春季校园巡回招聘系列活动走进南京师范...
加速“AI+”赋能 推动数智服... 早在春节期间,江苏移动就已基于自研的智宇模型平台,全面接入DeepSeek,为AI技术迈向普惠化强势...
“泰山+”激活文旅发展新引擎 转自:光明日报  近日,在山东泰安泰山景区,来自济南的游客王先生利用登山助力机器人,轻松地攀登泰山,...
女律师“闯关”聚宝山公园 3月7日,国际妇女节来临之际,南京聚宝山公园举办了一场女律师“闯关赛”。100多位女律师游园赏花、趣...
法兰西园林中的中国景观 转自:光明日报    尚特鲁庄园的中国式宝塔 资料图片    卡桑公园的中国八角亭 资料图片    ...
海州:奋力建设现代化中心城区 航拍海州 大陆汽车电子无人化车间用高品质成就全球最具竞争力的传感器工厂 盐河巷 悟...
全国政协委员、宁夏回族自治区政... 转自:千龙网“宁夏区域面积虽小但文化旅游资源丰富,有着得天独厚、文旅相融的发展机遇。”全国政协委员、...