每天学一点Swift----闭包(三)

2017-05-22  本文已影响22人  冯可乐同学

八.捕获上下文中的变量和常量

1.闭包可以用访问或修改闭包所在上下文中的变量或常量(对于常量只是访问),这个过程被称为捕获。

2.即使定义这些变量或常量的作用域已经不存在了,闭包也依然可以访问或修改他们。

3.Swift中最简单的闭包形式就是嵌套函数,嵌套函数可以捕获它所在的封闭韩式的变量、常量或参数。举个栗子:

//定义一个函数,该函数返回值的类型为() -> [String]

func makeArray(ele : String) -> () -> [String]

{

var arr : [String] = []

func addEle() -> [String]

{

arr.append(ele)

return arr

}

return addEle

}

上面的函数makeArray中的嵌套函数addEle()函数没有定义任何参数,也没有定义任何变量,但该嵌套函数可以访问arr变量和ele形参。这是因为嵌套函数捕获了其所在上下文中但变量。

****----很容易理解,主要是看makeArray()函数中的变量的作用域的范围。

4.每个闭包都会持有一个它捕获的变量的副本,为了证明,我们只需打印一下即可:

let result1 = makeArray(ele:"Swift")

print(result1()) ----注意这里一定要用result1加()的方式入参数,不然打印的是关键字Function

print(result1()) ----注意这里一定要用result1加()的方式入参数,不然打印的是关键字Function,并且只打印一个。

//结果是:

[swift]

[swift, swift]

let result2 = makeArray(ele:"bibao")

print(result2()) //输出:[bibao]

print(result2())//输出:[bibao,bibao]

九.闭包是引用类型

1.上面的例子中,result1,result2都是常量,但这些常量所引用的闭包依然可以改变它们底层持有的arr副本,这是因为函数和闭包都是引用类型。

2.当把一个函数或者闭包赋值给一个变量或常量时,程序并未真正使用该变量或常量来存储这个函数或闭包,程序只是让该变量引用了被赋值的函数或闭包,所以该变量成为了引用类型的。----也就是说,当程序把一个闭包赋值给两个引用变量时,程序并不会复制它们,而是让两个引用变量都指向同一个闭包。例如在上面的例子中再添加以下代码:

let result3 = result2

print(result3)//输出[bibao,bibao,bibao]

print(result3)//输出[bibao,bibao,bibao,bibao]

以上就是闭包的基本的内容。

上一篇 下一篇

猜你喜欢

热点阅读