特定泛型类型参数的解决方法

时间:2016-10-28 19:18:21

标签: ios swift generics

情况:

我有两个协议,一个使用静态方法:

protocol DataSourceable {
    static func getMoreData<T: DataAccepting>(someObject: T)
}

protocol DataAccepting {
    func accept(data: [Any])
}
extension DataAccepting where Self: UIViewController { }
编译好的

一旦我定义了一个类型参数符合DataSourceable的类:

class SampleViewController<T: DataSourceable>: UIViewController {...}

我得到Segmentation Fault: 11并且编译器崩溃了。

    0  swift                    0x0000000112445b6d PrintStackTraceSignalHandler(void*) + 45
    1  swift                    0x00000001124455b6 SignalHandler(int) + 470
    2  libsystem_platform.dylib 0x00007fffa4bd9bba _sigtramp + 26
    3  libsystem_platform.dylib 0x0000000000000002 _sigtramp + 1531077730
    4  swift                    0x000000010f8bd5bd swift::irgen::emitCategoryData(swift::irgen::IRGenModule&, swift::ExtensionDecl*) + 2285
    5  swift                    0x000000010f8c2425 swift::irgen::IRGenModule::emitGlobalDecl(swift::Decl*) + 1189
    6  swift                    0x000000010f8c1e85 swift::irgen::IRGenModule::emitSourceFile(swift::SourceFile&, unsigned int) + 133
    7  swift                    0x000000010f98dfe2 performIRGeneration(swift::IRGenOptions&, swift::ModuleDecl*, swift::SILModule*, llvm::StringRef, llvm::LLVMContext&, swift::SourceFile*, unsigned int) + 1282
    8  swift                    0x000000010f85c1c7 performCompile(swift::CompilerInstance&, swift::CompilerInvocation&, llvm::ArrayRef<char const*>, int&, swift::FrontendObserver*) + 23687
    9  swift                    0x000000010f854265 swift::performFrontend(llvm::ArrayRef<char const*>, char const*, void*, swift::FrontendObserver*) + 17029
    10 swift                    0x000000010f81182d main + 8685
    11 libdyld.dylib            0x00007fffa49cd255 start + 1
    12 libdyld.dylib            0x00000000000000c6 start + 1533226610
    **More_Stuff**...
    While emitting IR for source file /xx/xx/xx/xx/xx/xx/xx/SampleViewController.swift

最终目标是能够做到这一点:

class SampleViewController<T: DataSourceable>: UIViewController, DataAccepting {
var intArray = [Int]()
    func setup() {
        T.getMoreData(dataAcceptor: self)
    }

    func accept(data: [Any]) {
        intArray = data
    }
}

struct SampleModel: DataSourceable {
    static func getMoreData<T: DataAccepting>(dataAcceptor: T) {
        var anIntArray = [Int]()
        someObject.accept(anIntArray)
    }
}

然后制作SampleViewController<SampleModel>。 这将允许我让SampleModel处理控制器的源数据。 SampleModel决定如何获取数据,然后使用控制器上的accept()函数将数据提供给SampleController。

1 个答案:

答案 0 :(得分:1)

这似乎是一个编译器错误。但是,正如我们在chat中所讨论的那样,您应该避免使用此设计。