php小编草莓为您介绍一种特定字段的通用结构,用于将访问传递给可变参数函数。可变参数函数是一种接受不定数量参数的函数,但在实际应用中,我们常常需要将特定字段的值传递给这些函数。通过这种通用结构,我们可以轻松地将访问传递给可变参数函数,并指定特定字段的值,从而实现更灵活和精确的参数传递。这种通用结构可以大大简化我们的代码,并提高代码的可读性和可维护性。
问题内容
假设我有一个名为 foo
的通用 struct
:
type foo[t any] struct {
data t
}
登录后复制
我有一个可变参数函数,我想将一些 foo
s 传递给它。它们可以是任何类型的 foo
。我的理解是,因为 foo[int]
与 foo[string]
不同,所以我需要将省略号定义为 any
类型,如下所示:
func bar(things ...any) {
for _, v := range things {
fmt.println(v)
}
}
登录后复制
这确实有效。
func main() {
a := foo[string]{"cheese"}
b := foo[int]{42}
bar(a, b)
}
登录后复制
我的问题是我想专门访问每个 foo
中的 data
字段。但是如果我像这样定义 bar
,
func bar(things ...any) {
for _, v := range things {
fmt.println(v.data)
}
}
登录后复制
编译器会感到不安,这是可以理解的,因为 things
可能是任何东西,因此不能保证它们具有 data
字段。
我知道会有一个名为 data
的字段,因为我总是传递 foo
s,但我不能指定我只传递 foo
s,就像这样,
func bar(things ...foo) {
for _, v := range things {
fmt.Println(v.data)
}
}
登录后复制
因为没有指定foo
的类型。
如何将未指定数量的 foo
传递给 bar
,然后访问 data
字段?
解决方法
一种解决方案似乎是使用反射并使用 fieldbyname
访问该字段:
func bar(things ...any) {
for _, v := range things {
x := reflect.ValueOf(v)
fmt.Println(x.FieldByName("data"))
}
}
登录后复制
我不清楚这是否会因为某种原因被认为是一种障碍和/或危险。据推测,我需要在那里进行一些检查,以确保 things
中的所有内容实际上都是某种 foo
,否则我可能会尝试访问不存在的字段。
以上就是访问传递给可变参数函数的通用结构的特定字段的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!