swift – 在Generic中使用类型变量
除了
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 我发现这个幻灯片特别有助于理解协议和动态调度: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |