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

Swift协议泛型为函数返回类型

我想使用通用协议类型作为函数返回类型,如下所示:

protocol P {
  associatedtype T
  func get() -> T?
  func set(v: T)
}

class C<T>: P {
  private var v: T?
  func get() -> T? {
    return v
  }
  func set(v: T) {
    self.v = v
  }
}

class Factory {
  func createC<T>() -> P<T> {
    return C<T>()
  }
}

但是这个代码编译错误抱怨:

>不能专门化非泛型类型’P’
>通用参数“T”未在函数签名中使用

有没有办法用Swift实现类似的功能

解决方法

问题是你不能使用语法P< T>. P是一个协议,意味着它不能被视为泛型类型(不能专门化非泛型类型’P’),即使它可能具有给定的关联类型.

事实上,因为它有一个关联类型,你现在甚至不能直接使用协议类型本身 – 你只能将它用作通用约束.

解决您的问题的一个方法是简单地将您的功能签名更改为createC< T>() – > C< T>,因为它正是它返回的.

class Factory {
    func createC<T>() -> C<T> {
        return C<T>()
    }
}

我不完全确定将返回类型作为协议来获得什么.据推测,您的示例只是对实际代码的简化,并且您希望能够返回符合P的任意实例.在这种情况下,您可以使用type erasure

class AnyP<T> : P {

    private let _get : () -> T?
    private let _set : (T) -> ()

    init<U:P where U.T == T>(_ base:U) {
        _get = base.get
        _set = base.set
    }

    func get() -> T? {return _get()}
    func set(v: T) {_set(v)}
}
class Factory {
    func createC<T>() -> AnyP<T> {
        return AnyP(C<T>())
    }
}

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

相关推荐