协议是否可以具有静态工厂方法的默认实现?

时间:2016-12-01 04:55:03

标签: swift protocols

考虑具有工厂方法的协议:

public protocol Frobnicator {

  func frobnicate()

  static func makeRightFrobnicator() -> Frobnicator
}

private class SomeFrobnicatorImplementation: Frobnicator { ... }
private class AnotherFrobnicatorImplementation: Frobnicator { ... }

public extension Frobnicator {

  static func makeRightFrobnicator() -> Frobnicator {
    if something {
      return SomeFrobnicatorImplementation()
    } else {
      return AnotherFrobnicatorImplementation()
    }
  }
}

我希望能够在不同的时间构建不同的实现者。实现者本身对模块是私有的,而协议在客户端代码中是公共的。

当我尝试类似上面的代码时,我得到“静态成员makeRightFrobnicator不能用于协议元类型Frobnicator.Protocol。”

有没有解决方法,或者我应该使用免费功能?

1 个答案:

答案 0 :(得分:4)

静态功能实现是合法的:

protocol P {
    static func f() -> P
    init()
}

extension P {
    static func f() -> P {return self.init()}
}

但是你会注意到为了让它编译,我必须向编译器保证我手头有一个合法的方法来制作一个P以便能够返回一个。

您的代码中的问题是尝试返回协议的特定采用者,例如SomeFrobnicatorImplementation。协议对谁采用它是不可知的。换句话说,您无法在协议定义中保证SomeFrobnicatorImplementation实际上将成为此协议的采用者。因此,您的代码部分是非法的。