深入理解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 在变量中也能定义。

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