swift - 如何将集合的 Swift 扩展限制为泛型类型?

标签 swift dictionary generics extension-methods

因为元组在 Swift 中不可散列,所以我创建了一个通用结构 Couple 来包含两个元素,这两个元素组合起来可以用作字典的键。

struct Couple<U: Hashable, V: Hashable>: Hashable {
    let u: U
    let v: V

    init( _ u: U, _ v: V ) {
        self.u = u
        self.v = v
    }
}
var dictionary: [ Couple<Int,Int> : Any ] = ...

现在,我想一般使用 Couple 来扩展 Dictionary。

extension Dictionary where Key == Couple<U: Hashable, V: Hashable>, Value == Any {
    func exampleConvertToArray() -> [ ( U, V, Any ) ] {
    }
}

无论我在扩展语句中如何引用 Couple、U、V,编译器都会提示。如果我将泛型添加到函数定义中,编译器也会提示。

如果类型不是泛型 ( extension Dictionary where Key == Couple<Int, Int>, Value == Any ),则一切正常。

如何创建这个通用扩展?

最佳答案

这是可能的,但不幸的是,通用约束必须在成员本身上表达,而不是在整个扩展上:

struct Couple<U: Hashable, V: Hashable>: Hashable {
    let u: U
    let v: V

    init( _ u: U, _ v: V ) {
        self.u = u
        self.v = v
    }
}

extension Dictionary {
    func exampleConvertToArray<U, V>() -> [(U, V, Any)] where Key == Couple<U, V> {
        self.map { (key, value) in (key.u, key.v, value) }
    }
}

let input = [
    Couple(1, 2): 3,
    Couple(4, 5): 6,
    Couple(7, 8): 9,
]

let result = input.exampleConvertToArray()
print(result)

关于swift - 如何将集合的 Swift 扩展限制为泛型类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60470848/

相关文章:

ios - 如何修复链接器命令因退出代码 1 错误而失败?

c# - 有没有一种通用的方法可以通过 C# 中的反射来填充各种通用集合?

ios - 在 Swift 2.3 中导航到 UIViewController

dictionary - 如何访问模板字符串中的 map ?

Python:按键(元组)将字典拆分为更小的字典

c++ - std::map 不插入空?

c++ - 压扁容器容器的通用函数

c# - 允许按位运算的通用约束?

arrays - 如何使用变量将字符串追加到数组中? swift

ios - 加载 usdz 文件时出现内存问题