我在使用 reflect
从 struct
迭代 *T funcs
时遇到一些问题。
我搜索了很多答案,但似乎没有一个专门讨论这种情况。
我在 golang 文档中找到了 reflect.NewAt
但说实话我不明白,而且我再次找不到适合我情况的答案。
为了更好地理解......通过使用以下结构:
type Counter struct {}
func (self *Counter) Add(n int) {}
如果我通过调用结构指针本身来使用反射,它会按预期工作:
y := reflect.TypeOf(&Counter{})
for k := 0; k < y.NumMethod(); k++ {
fmt.Println(y.Method(k)) // {Add func(*Counter, int) <func(*Counter, int) Value> 0}
}
但就我而言,多个结构可以到达这里,因此它作为接口(interface)到达:
var p interface{} = Counter{}
z := reflect.New(reflect.TypeOf(p))
for k := 0; k < z.NumMethod(); k++ {
fmt.Println(z.Method(k)) // 0x47d150
}
但如图所示,它打印了内存地址。
我希望 0x47d150
与我直接使用指针的输出相同。我在这里做错了什么?
最佳答案
值y
是reflect.Type
。类型上的 Method
方法相当于 method expression .
值z
是一个reflect.Value
。值上的 Method
方法相当于 method value .
打印的表示不同,因为方法表达式和方法值不是同一件事。
使用reflect.PtrTo
获取类型的指针类型:
var p interface{} = Counter{}
z := reflect.PtrTo(reflect.TypeOf(p))
for k := 0; k < z.NumMethod(); k++ {
fmt.Println(z.Method(k)) // {Add func(*Counter, int) <func(*Counter, int) Value> 0}
}
接口(interface)中的具体值是一个非指针值。如果接口(interface)中的具体值是指针类型,则可以使用此代码:
var p interface{} = &Counter{}
z := reflect.TypeOf(p)
for k := 0; k < z.NumMethod(); k++ {
fmt.Println(z.Method(k)) // {Add func(*Counter, int) <func(*Counter, int) Value> 0}
}
关于go - 如何通过reflect.TypeOf(interface{})从struct迭代*T funcs?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55409516/