在此代码中:
class Foo {
}
func go(input: Foo) {
print("Non-generic called")
}
func go<T>(input: T) {
print("Generic called")
}
var foo:Foo = Foo()
go(foo) // Non-generic called
我只是好奇为什么调用非泛型版本而不是泛型版本?编译器只是将特定类型优先于泛型吗?
发布于 2016-01-18 18:44:02
编译器对约束最严格的函数进行排序。因此,与需要子类型的where
子句匹配的函数将优先于与需要超级类型的where
子句匹配的函数。与where
子句匹配的函数将击败不匹配的函数,显式调用其类型的函数将击败仅在泛型上匹配的函数。具体的规则非常复杂(在某些情况下,当事情处于边缘时,似乎是a little ad hoc ),但总的来说,这就是目的所在。
您可以将上面的内容想象为:
// Any T
func go<T>(input: T) {
print("Generic called")
}
// A very constrained T, so clearly you wanted to override.
func go<T where T == Foo>(input: T) {
print("Non-generic called")
}
https://stackoverflow.com/questions/34861755
复制相似问题