php小编柚子在这里为大家介绍如何使用带有方法的字符串枚举作为泛型参数。在编程中,我们经常需要使用泛型来增加代码的灵活性和可重用性。而使用带有方法的字符串枚举作为泛型参数,可以使我们的代码更加简洁和高效。接下来,我们将详细阐述如何实现这一功能,并给出具体的示例代码。让我们一起来探索这个有趣的编程技巧吧!
问题内容
我有多个字符串派生的枚举,它们共享一个通用的 validate()
方法(全部超出我的控制范围)。我想要一个通用方法,将字符串转换为这些枚举,并在生成的枚举上调用 validate()
。我尝试使用泛型来实现这一目标,但由于各种原因失败了。
在下面的示例中,类型约束太强,导致无法调用 validate()
。我还尝试使用 validate()
方法插入我自己的接口并将其用作类型约束,但随后在类型转换部分失败。
如何在不修改枚举的情况下实现此目的?
package main
// imagine i have multiple of those types outside of my control
type FooStatusEnum string
func NewFooStatusEnum(value FooStatusEnum) *FooStatusEnum {
return &value
}
const (
FooStatusEnumA FooStatusEnum = "A"
FooStatusEnumB FooStatusEnum = "B"
FooStatusEnumC FooStatusEnum = "C"
)
func (m FooStatusEnum) Validate() error {
return nil
}
func stringToValidatedEnum[E ~string](s string) E {
e := E(s)
if err := e.Validate(); err != nil {
panic(1)
}
return e
}
func main() {
stringToValidatedEnum[FooStatusEnum]("A")
e := FooStatusEnum("A")
e.Validate()
}
解决方法
使用指定 string
基础类型和 validate()
方法的类型约束:
type enumstring interface {
~string
validate() error
}
func stringtovalidatedenum[e enumstring](s string) e {
e := e(s)
if err := e.validate(); err != nil {
panic(1)
}
return e
}
测试它:
result := stringtovalidatedenum[foostatusenum]("a")
fmt.printf("%t %v", result, result)
这将输出(在 go playground 上尝试):
main.FooStatusEnum A
以上就是如何使用带有方法的字符串枚举作为泛型参数?的详细内容,更多请关注编程网其它相关文章!