有人可以解释这个错误以及为什么这适用于闭包?
如果你在'B'类中将'Test'更改为'A',那么在这两种情况下一切都有效。
beta 7
protocol Test {
func someFunc() -> String
var someClosure: () -> Int { get }
}
class A: Test {
func someFunc() -> String {
return "A String"
}
var someClosure: () -> Int {
return {
return 2
}
}
}
class B {
let a: Test
let aString: () -> String
let aInt: () -> Int
init(a: Test){
self.a = a
aString = a.someFunc // Error: Partial application of protocol method is not allowed
aInt = a.someClosure // Works fine
}
}
更新
此处还有我奇怪的分段错误集合https://gist.github.com/aleksgapp/795a2d428008bdfa4823
如果您对任何想法有任何想法,请随时发表评论。
答案 0 :(得分:7)
更新(感谢Laszlo Korte)
来自Xcode 7 Beta 2和Swift 2.0发行说明:非变异方法 结构,枚举和协议现在可以部分应用于他们的 “自我”参数。
例如:
let a: Set<Int> = [1, 2]
let b: [Set<Int>] = [[1], [3]]
b.map(a.union) // [[1, 2], [1, 2, 3]]
原始回答(使用Swift 1.2更正Xcode 6)
协议可以通过类,结构或枚举来采用。在最后两种情况下,不允许部分应用结构或枚举方法,并且你得到&#34;不允许部分应用协议方法&#34;因为a: Test
可以是结构或枚举。
部分应用的方法或功能换句话说是curried method or function
。因此,当您编写a.someFunc
时,您尝试部分应用此方法,即获取对隐式持有a
引用的闭包的引用。但是结构和枚举不是引用类型,它们是值类型,并且没有a
的引用。
答案 1 :(得分:3)
所以,我不能说为什么它的行为是这样的,但我确实找到了解决方法。 试试这个:
aString = { return a.someFunc() }