ios – 如何添加@noescape注释到可选闭包

前端之家收集整理的这篇文章主要介绍了ios – 如何添加@noescape注释到可选闭包前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的功能有这个签名:
func foo(bar: String,baz: ((String) -> ())? = nil)

而现在我想让自己在给定的关闭中逃脱自我.
但是当我尝试这个:

func foo(bar: String,@noescape baz: ((String) -> ())? = nil)

编译器抱怨:

@noescape may only be applied to parameters of function type

是否可以在可选参数中使用它?

解决方法

要求

如果您的要求如下:

baz param是封闭
> baz param被标记为@noescape(因为你想在关闭代码中省略自己)
>在调用foo时可以省略baz param

然后可以使用以下语法

func foo(bar: String,@noescape baz: ((String) -> ()) = { _ in } ) {

}

你可以看到与你的代码的主要区别是:

>这里baz不是一个可选类型(但它是一个“可选参数”)
>并且其默认值是一个空的闭包不是一个零值.

例子

如您所要求的,您现在可以将封闭物传递给baz,而无需使用自身

class Boo {
    let world = "world"
    func boo() {
        foo("hello") { (something) -> () in
            print(world)
        }
    }
}

你也可以省略baz param

class Boo {
    let world = "world"
    func boo() {
        foo("hello")
    }
}

更新:使用与Void不同的返回类型的闭包

在下面的评论中,用户TadeasKriz询问如何使用这种方法与一个闭包返回值不同Void.

这是解决方

func foo(bar: String,@noescape baz: ((String) -> (Int)) = { _ in return 0 } ) {

}

这里的baz param确实需要一个类型为String的String参数和类型为Int的返回值的闭包.
正如你所看到的,我添加了一个默认值到param,一个闭包确实返回0.请注意,默认的关闭将永远不会被使用,所以你可以用你想要的任何Int值替换0.

现在你可以决定是否使用关闭到baz param

class Boo {
    let world = "world"
    func boo() {
        foo("hello") { (something) -> Int in
            print(world)
            return 100
        }
    }
}

或者,再次,你可以完全省略巴斯参数.

class Boo {
    let world = "world"
    func boo() {
        foo("hello")
    }
}

猜你在找的iOS相关文章