除了
Swift,我有
this question.如何在泛型中使用Type变量?
我试过这个:
func intType() -> Int.Type { return Int.self } func test() { var t = self.intType() var arr = Array<t>() // Error: "'t' is not a type". Uh... yeah,it is. }
这也不行:
var arr = Array<t.Type>() // Error: "'t' is not a type" var arr = Array<t.self>() // Swift doesn't seem to even understand this Syntax at all.
有没有办法做到这一点?我得到Swift只是不支持它,并给我一些含糊不清的错误消息的感觉.
编辑:这是一个更复杂的例子,其中使用通用函数头不能规避问题.当然这没有意义,但是我对代码中某处的这种功能有一个明智的用途,而是发布一个干净的例子而不是我的实际代码:
func someTypes() -> [Any.Type] { var ret = [Any.Type]() for (var i = 0; i<rand()%10; i++) { if (rand()%2 == 0){ ret.append(Int.self) } else {ret.append(String.self) } } return ret } func test() { var ts = self.someTypes() for t in ts { var arr = Array<t>() } }
Swift的
static typing表示在编译时必须知道变量的类型.
在通用函数func foo(T)(){…}的上下文中,T看起来像一个变量,但是它的类型在编译时基于从哪里调用函数而已知. Array T()的行为取决于T,但是在编译时这个信息是已知的.
当使用协议时,Swift采用动态调度,因此您可以编写Array&MyProtocol>(),数组简单地存储对实现MyProtocol的事物的引用 – 所以当您从数组中获取数据时,您可以访问所有函数/变量/我的协议要求的typealiases.
但是如果t实际上是Any.Type的变量,那么Array< t>()是无意义的,因为它的类型在编译时实际上是未知的. (由于Array是一个通用的结构,编译器需要知道要使用哪个类型作为通用参数,但是这是不可能的.)
今年我会推荐看WWDC的一些视频:
> Protocol-Oriented Programming in Swift
> Building Better Apps with Value Types in Swift
我发现这个幻灯片特别有助于理解协议和动态调度: