微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

协议和泛型类型中的Swift类型

我有一个协议,有一个typealias:

protocol Fooable {
    typealias T: Equatable
    func makeFoo() -> T
}

我希望,符合它的所有类型都将从makeFoo返回Equatable值.

现在我想创建一个数组扩展,它存储Fooable值:

extension Array where Element: Fooable {

    func arrayFoo<F: Foobable,S>(array: Array<F>,transform: (Element,[F]) -> S) -> [S] {

我希望,给定数组A,其中包含Fooable元素和数组B,其中包含我可以制作的Fooable元素:

a.arrayFoo(b,{...})

我有一部分arrayFoo函数

var leftGenerator = self.generate()
var rightGenerator = array.generate()

if let leftValue = leftGenerator.next(),rightValue = rightGenerator.next() {
    let leftFoo = leftValue.makeFoo()
    let rightFoo = rightValue.makeFoo()

    if leftFoo == rightFoo {

我希望leftFoo和rightFoo是Equatable,因为它们是由makeFoo()生成的,它应该返回Equatables.

但Swift抱怨:二进制运算符==不能应用于Element.T和F.T类型的操作数

任何想法或解决方法

解决方法

在您的arrayFoo()方法中,array和self都是数组
Fooable元素,但不一定具有相同的底层元素
类型T,即Element.T和F.T是不相关的类型.

您可以使用其他约束来解决此问题
其中F.T == Element.T类型占位符:

func arrayFoo<F: Fooable,S where F.T == Element.T >(array: Array<F>,[F]) -> S) -> [S] {
    // ...
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐