我正在尝试在 swift 中编写一个函数,在这样的通用函数中创建一个 rawValue 枚举:
enum STATE: String {
case OK = "OK"
case ERROR = "ERROR"
}
func createEnum<E: RawRepresentable>(rawValue: T.Type) {
return E(rawValue: rawValue) // compiler error
}
我错过了什么吗?
我正在尝试在 swift 中编写一个函数,在这样的通用函数中创建一个 rawValue 枚举:
enum STATE: String {
case OK = "OK"
case ERROR = "ERROR"
}
func createEnum<E: RawRepresentable>(rawValue: T.Type) {
return E(rawValue: rawValue) // compiler error
}
我错过了什么吗?
如前所述,如果你想要return
任何东西,你的函数需要一个返回类型。由于您似乎想使用该函数来创建指定枚举类型的值,因此该返回类型可能应该是E
or E?
。(您正在包装init?(rawValue:)
,它返回一个可选,因为rawValue
可能不会映射到枚举案例之一。因此,您要么希望将可选传递给调用者,要么在函数中有一些逻辑来解包并处理 nil 案例。)
你的参数rawValue
还需要一个真实的类型——T.Type
在你的声明中不是一个完全限定的类型。您可以使用协议(您已经作为通用约束给出)定义的类型RawValue
别名来获取枚举的原始值类型。RawRepresentable
所以,这是你的功能:
func createEnum<E: RawRepresentable>(rawValue: E.RawValue) -> E? {
return E(rawValue: rawValue)
}
请注意,如果您尝试这样的事情:
enum Foo: Int {
case One = 1
case Two = 2
}
createEnum(1)
createEnum<Foo>(1)
它不起作用——第一个没有指定使用泛型函数的哪个特化,第二个不起作用,因为 Swift 不允许手动对泛型函数进行特化。相反,您必须对其进行设置,以便类型推断能够发挥作用:
let f: Foo? = createEnum(1)
someFuncThatTakesAFoo(createEnum(1))