swift 深入理解Swift的闭包
我们可用swift的闭包来定义变量的值。 先来一个简单的例子大家先感受感受。
定义一个字符串的变量的方法:
直接赋值
var str="JobDeer"
还可以用闭包的方式定义:
var str:String={
return "JobDeer"
}()
闭包还可以这么定义,省略了等号和括号:
var str:String{
return "JobDeer"
}
闭包中可以定义get方法。
var str:String{
get{
return "JobDeer"
}
}
既然用可以用get方法, 那么能用set方法吗?
可以的:
var str:String{
get{
return "JobDeer"
}
set{
println("set ok")
}
}
我们在用 willSet 和didSet方法试一试, 注意 用 willSet /didSet不能和get/set共同使用的, 在使用willSet /didSet时,变量需要有初始值。 所以这么使用:
var str:String="JobDeer"{
willSet{
println("newValue:\(newValue)")
}
didSet{
println("oldValue:\(oldValue)")
}
}
str="new value"
通过上面这个例子, 我们感觉闭包的表达实现形式很多。 下面系统总结一下。
最全的定义形式是 :
{
(arguments) ->returnType in
code
}(arguments)
可以在闭包中定义参数,返回值。 闭包后用括号执行,并在括号中可以传参。 例如:
var str={
(arg1:String,arg2:String)->String in
return arg1+arg2;
}("Job","Deer")
基于上面最全的定义方式, 我么可以省略参数的类型:
var str={
arg1,arg2->String in
return arg1+arg2;
}("Job","Deer")
为什么能省略参数类型? 那是因为, swift的类型推导,根据后面括号的传参能自动判断参数的类型。
然后我们可以省略闭包中的返回值类型
var str:String={
arg1,arg2 in
return arg1+arg2;
}("Job","Deer")
注意,闭包省略了返回值类型后,变量要显示声明它的类型, 之所以能省略返回值类型,那也是因为swift类型推导,先知道了变量的类型,所以可以省略返回值类型。
还不够爽,我们可以把参数也省略了
var str:String={
return $0+$1;
}("Job","Deer")
如果闭包中只有一行代码, 其实return 也能省略。
var str:String={
$0+$1;
}("Job","Deer")
如果闭包没有定义参数 ,像这样
var str:String={
return "JobDeer"
}()
括号中根本没有传参数, 括号能不能省略呢?
可以把括号省略了
省略括号的同时等号也不能写
var str:String{
return "JobDeer"
}
上面这种闭包表现方法似曾相识, 如果你学过swift的类,知道类的属性可以用闭包表示, 可以在闭包中定义 set, get , willSet,didSet等方法。 那么上面变量是否也能这样定义呢?
答案是肯定的:
可以定义set,get,willSet,didiSet等方法
var str:String{
get{
return "JobDeer"
}
set{
println("set ok")
}
}
或者:
var str:String="JobDeer"{
willSet{
println("newValue:\(newValue)")
}
didSet{
println("oldValue:\(oldValue)")
}
}
str="new value"
其实类的属性就是变量。 类的属性能定义的 set, get , willSet,didSet 在变量中也能定义。