如何在 Swift 中扩展类型化数组?

发布于 2022-07-28 23:16:31

如何使用自定义功能工具扩展 SwiftArray<T>T[]类型?

浏览 Swift 的 API 文档表明 Array 方法是 的扩展T[],例如:

extension T[] : ArrayType {
    //...
    init()

    var count: Int { get }

    var capacity: Int { get }

    var isEmpty: Bool { get }

    func copy() -> T[]
}

复制和粘贴相同的源并尝试任何变体时,例如:

extension T[] : ArrayType {
    func foo(){}
}

extension T[] {
    func foo(){}
}

它无法构建并出现以下错误:

标称类型T[]不能扩展

使用完整类型定义失败Use of undefined type 'T',即:

extension Array<T> {
    func foo(){}
}

它也失败了Array<T : Any>and Array<String>

奇怪的是 Swift 允许我扩展一个无类型数组:

extension Array {
    func each(fn: (Any) -> ()) {
        for i in self {
            fn(i)
        }
    }
}

它让我打电话给:

[1,2,3].each(println)

但是我无法创建适当的泛型类型扩展,因为类型在流经该方法时似乎丢失了,例如尝试将 Swift
的内置过滤器替换为

extension Array {
    func find<T>(fn: (T) -> Bool) -> T[] {
        var to = T[]()
        for x in self {
            let t = x as T
            if fn(t) {
                to += t
            }
        }
        return to
    }
}

但是编译器将其视为无类型,它仍然允许使用以下方式调用扩展:

["A","B","C"].find { $0 > "A" }

并且当使用调试器逐步指示类型是Swift.String但尝试像字符串一样访问它而不将其转换为String第一个时,这是一个构建错误,即:

["A","B","C"].find { ($0 as String).compare("A") > 0 }

有谁知道创建类似于内置扩展的类型化扩展方法的正确方法是什么?

关注者
0
被浏览
11
1 个回答
  • 面试哥
    面试哥 2022-07-28
    为面试而生,有面试问题,就找面试哥。

    对于使用 classes 扩展类型化数组,以下适用于我(Swift 2.2 )。例如,对类型化数组进行排序:

    class HighScoreEntry {
        let score:Int
    }
    
    extension Array where Element == HighScoreEntry {
        func sort() -> [HighScoreEntry] {
          return sort { $0.score < $1.score }
        }
    }
    

    尝试使用 structtypealias 执行此操作会出错:

    Type 'Element' constrained to a non-protocol type 'HighScoreEntry'
    

    更新

    要使用非类 扩展类型化数组,请使用以下方法:

    typealias HighScoreEntry = (Int)
    
    extension SequenceType where Generator.Element == HighScoreEntry {
        func sort() -> [HighScoreEntry] {
          return sort { $0 < $1 }
        }
    }
    

    Swift 3 中,一些类型被重命名:

    extension Sequence where Iterator.Element == HighScoreEntry 
    {
        // ...
    }
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看