swift 之循环语句和闭包
来源:互联网 发布:单片机资源百度云盘 编辑:程序博客网 时间:2024/06/03 21:06
1.流程控制
swift使用三种语句控制流程:for-in
、for
、switch-case
、while
和repeat-while
,且判断条件的括号可以省略
for-in
循环
let names = ["Jack", "Rose", "Mike", "Puppy"]for name in names { print("Hello, \(name)!")}//如果不需要使用到迭代的值,使用下划线`_`忽略该值for _ in 1...10 print("hello")
if
语句
原来在oc中,if后的条件语句可以是这样:
假设judge是一个BOOL型或NSString或NSArray或NSDictionary等类型if (judge){//write code...}
但在swift中,if后的条件返回值必须是Bool型,在写成上面的那种情形就会报错…. 所以在swift中这样写:
if judge == true {//write code...}
在Swift2.0以后,不支持do-while
语句,使用repeat-whil
e代替,用法与do-while
一样:
repeat { print("repeat while : \(j)") j++ } while j < 3
guard-else
保镖模式
在执行操作前,进行检查,如果不符合,则拦截,使用方式与if有些类似,如果与let结合使用,可以对可选类型解包,先看看普通的if-else
模式:
func test(i: Int?) { if let i = i where i > 0 { // 符合条件的处理 return } // 不符合条件的处理}
上面的处理把条件放在了条件判断内部,使用guard与之相反,把正确的情况放在最外部,而异常情况放在条件判断内部:
func test(i: Int?) { guard let i = i where i > 0 else { // 在这里拦截,处理不符合条件的情况 return } // 符合条件的处理,这个时候已经对i进行了拆包,i是非可选类型,可以直接使用 print(i)}
保镖模式可以避免代码中过多的流程判断代码导致过多的代码块嵌套,增强可读性!!!
保镖模式guard-else
内的代码块必须包含break
, return
等跳出代码块的关键字
switch-case
swift中的switch
语句最明显的区别于oc的地方在于,不需要break
2. 函数(方法)
1.基本形式
///单个返回值func 函数名称(参数1: 参数1类型, 参数2: 参数2类型) -> 返回值 { //函数体}///多个返回值(元组)func 函数名称(参数1: 参数1类型, 参数2: 参数2类型) -> (x: String, y: Int) { //函数体return ("abc", 3)}///无返回值func 函数名 {}
还有一种相当于oc中的加号方法:
class func 函数名(参数: 参数类型) -> 返回值类型 {}
2.闭包
///闭包函数声明形式:{ (parameters) -> returnType in statements // 可以有多行}
闭包函数
//定义一个函数变量var addfunc: (Int, Int) -> Int//闭包的写法// 1. 完整写法addfunc = {(a: Int, b: Int) -> (Int) in //var c = a + 1 //函数体可以有多条语句,如果在同一行,需要用分号隔开,函数体不需要大括号 return a + b}// 2. 前面的addfunc变量可以推断出后面函数的参数类型和返回值类型,故可以省略addfunc = {(a, b) in return a + b}// 3. 参数列表括号可以省去,函数只有一条语句时,return可以省略addfunc = {a, b in a + b}// 4. 参数和in可以省去,通过$和索引取得参数addfunc = {$0 + $1}// 操作符需要的参数与函数参数一致,可以省去参数,并使用括号括起来,作为参数时,可不用括号addfunc = (+)
3.Trailing(尾行)闭包
如果函数作为另一个函数的参数,并且是最后一个参数时,可以通过Trainling
闭包来增强函数的可读性
func someFunctionThatTakesAClosure(a: Int, closure: () -> ()) { // 函数体部分}// 1. 一般形式someFunctionThatTakesAClosure(10, closure: { // 闭包主体部分})// 2. Trainling闭包的方式someFunctionThatTakesAClosure(10) { // 闭包主体部分}// 3. 如果没有其他参数时,可以省略括号someFunctionThatTakesAClosure { // 闭包主体部分}
4.Escaping(逃逸)闭包
如果一个闭包/函数作为参数传给另外一个函数,但这个闭包在传入函数返回之后才会执行,就称该闭包在函数中”逃逸”,需要在函数参数添加@escaping
声明,来声明该闭包/函数允许从函数中”逃逸”,如下:
var completionHandlers: [() -> Void] = []// 传入的闭包/函数并没有在函数内执行,需要在函数类型钱添加@escaping声明func someFunctionWithEscapingClosure(completionHandler: @escaping () -> Void) { completionHandlers.append(completionHandler)}
逃逸闭包只是一个声明,以增强函数的意图
5.自动闭包
对于没有参数的闭包,swift提供了一种简写的方式,直接写函数体,不需要函数形式(返回值和参数列表),如下:
// 声明一个自动闭包(无参数,可以有返回值,返回值类型swift可以自动识别)let sayHello = { print("hello world") }//调用闭包函数sayHello()
自动闭包只是闭包的一种简写方式
如果一个函数接受一个不带参数的闭包:
func logIfTrue(predicate: () -> Bool) { if predicate() { print("True") }}
调用:
logIfTrue(predicate: { return 1 < 2 })// 可以简化returnlogIfTrue(predicate: { 1 < 2 })
上面代码看起来可读性不是很好,swift引入了一个关键字@autoclosure
,简化自动闭包的大括号,在闭包类型前面添加该关键字声明:
func logIfTrue(predicate: @autoclosure () -> Bool) { if predicate() { print("True") }}// 调用logIfTrue(predicate:1 < 2)
@autoclosure 关键字是为了简化闭包的写法,增强可读性,这里的例子比较简单,可以参考:了解更多点击这里
原文地址
- swift 之循环语句和闭包
- Swift教程之循环语句
- Swift - 条件语句和循环语句
- Swift闭包循环引用
- swift之闭包循环引用问题及解决方式
- swift学习之判断、循环语句
- Swift之函数和闭包
- swift基本语法(总结提炼版)之014 swift 之闭包循环引用
- Swift之闭包
- Swift之闭包
- Swift之闭包
- Swift中的循环语句
- Swift-条件语句&循环
- swift 2.0 循环语句
- Swift 循环语句
- swift中的循环语句
- swift中的循环语句
- IOS闭包循环引用(Swift)
- astra pro获取彩色图原始实例
- Ecliplse 远程调试
- 一些特殊运算符的理解
- 自动装箱的一点小细节
- android开源堆叠滑动控件,类似探探
- swift 之循环语句和闭包
- Hadoop安装教程_单机/伪分布式配置_Hadoop2.6.0/Ubuntu14.04
- BaseRecyclerViewAdapterHelper的配置
- wx.request在任何情况下都执行fail函数
- Java:泛型基础
- iOS开发:深入浅出iOS事件机制
- jquery点击下拉菜单鼠标移开隐藏(可模拟下拉框)
- telephony framework中的代理模式
- ubuntu 12.0.4环境下crosstool-ng 1.18.0编译ARM交叉编译器(Cortex-A8)