闭包(Closures) 4 – 理解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 在变量中也能定义。

原文: http://my.oschina.net/lanrenbar/blog/467768