IOS_Swift_深入理解閉包 對比懶載入和普通賦值的區別
定義一個字串的變數的方法:
//直接賦值var str="JobDeer"//閉包方式var str:String={ return "JobDeer"}()//簡化閉包,省略了等號和括弧:var str:String{ return "JobDeer"}
//閉包中可以定義get、set方法。 var str:String{ get{ return "JobDeer" } set{ println("set ok") }}//注意用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")//繼續簡化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"}
//////普通賦值var i = 0var up:Int?{ i = i+1 return i}for _ in 0...2{ print("-->\(up!)")}//-->1//-->2//-->3//閉包執行,I增加//////懶載入var id = 10class Animal { lazy var addID:Int? = { id++ return id }() init(){ }}let anim = Animal()print(anim.addID!)print(anim.addID!)//11//11//閉包執行,anim.addID並未再次增加