让我们假设如下:
enum MyEnum: String { case value }
let possibleEnum: Any = MyEnum.value
if let str = stringFromPossibleEnum(possibleEnum: possibleEnum)在不知道枚举类型名称的情况下实现stringFromPossibleEnum的最佳选择是什么?
func stringFromPossibleEnum(possibleEnum: Any) -> String? {
// how should this be implemented without knowing enum type name?
}UPD:,好的,这样我可以判断possibleEnum是否是一个枚举:
if Mirror(reflecting: possibleEnum).displayStyle == .enum { print("yes!") }但是如何判断这是否是一个String-based枚举呢?
UPD: 这条推特建议您可以从Enum获得rawValue。然后,您可能可以检查该rawValue是否为String。但是如何从rawValue获得Mirror
发布于 2017-05-09 11:09:06
好的,这基本上是不可行的,因为你不能as?-cast to RawRepresentable,而Mirror不为枚举提供rawValue。
我认为最好的选择是创建自己的protocol,为String-based RawRepresentable提供默认的实现,并手动遵守所有枚举,如下所示:
假设这些是枚举:
enum E1: String { case one }
enum E2: String { case two }
enum E3: String { case three }StringRawRepresentable协议和默认实现:
protocol StringRawRepresentable {
var stringRawValue: String { get }
}
extension StringRawRepresentable
where Self: RawRepresentable, Self.RawValue == String {
var stringRawValue: String { return rawValue }
}使所有需要的现有枚举符合议定书:
extension E1: StringRawRepresentable {}
extension E2: StringRawRepresentable {}
extension E3: StringRawRepresentable {}现在我们可以转换为StringRawRepresentable了
func stringFromPossibleEnum(possibleEnum: Any) -> String? {
if let e = possibleEnum as? StringRawRepresentable { return e.stringRawValue }
return nil
}
stringFromPossibleEnum(possibleEnum: E2.two as Any)发布于 2017-04-27 20:53:42
不知道你到底在努力实现什么,但这里是:
enum MyEnum: String {
case A
case B
case C
}
func stringFromEnum<T: RawRepresentable>(_ value: T) -> String
where T.RawValue == String {
return value.rawValue
}
print(stringFromEnum(MyEnum.A))
print(stringFromEnum(MyEnum.B))
print(stringFromEnum(MyEnum.C))https://stackoverflow.com/questions/43666118
复制相似问题