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
> Building Better Apps with Value Types in Swift

我发现这个幻灯片特别有助于理解协议和动态调度:

相关文章
相关标签/搜索