如何在 Swift 中扩展类型化数组?
如何使用自定义功能工具扩展 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 }
有谁知道创建类似于内置扩展的类型化扩展方法的正确方法是什么?
-
对于使用 classes 扩展类型化数组,以下适用于我(Swift 2.2 )。例如,对类型化数组进行排序:
class HighScoreEntry { let score:Int } extension Array where Element == HighScoreEntry { func sort() -> [HighScoreEntry] { return sort { $0.score < $1.score } } }
尝试使用 struct 或 typealias 执行此操作会出错:
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 { // ... }