深入理解Swift闭包

我们可用swift的闭包来定义变量的值。 先来一个简单的例子。

定义一个字符串的变量的方法:

直接赋值

var str="William"

还可以用闭包的方式定义:

var str:String={

return "William"

}()

闭包还可以这么定义,省略了等号和括号:

var str:String{

return "William"

 }

闭包中可以定义get方法。

var str:String{

get{

return "William"

   }

}

既然用可以用get方法, 那么能用set方法吗?

可以的:

var str:String{

get{

return "William"

}

set{

println("set ok")

}

}

我们在用 willSet 和didSet方法试一试,  注意 用 willSet /didSet不能和get/set共同使用的, 在使用willSet /didSet时,变量需要有初始值。 所以这么使用:

var str:String="William"{

   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,didSet等方法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 在变量中也能定义。

你可能感兴趣的:(深入理解Swift闭包)