*我們可用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
在變量中也能定義。