*我们可用swift的闭包来定义变量的值。 先来一个简单的例子大家先感受感受。 *
定义一个字符串的变量的方法:
1.直接赋值
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
在变量中也能定义。