2

我在*T funcsstructusing迭代时遇到了一些问题reflect

我搜索了很多答案,但似乎没有一个专门谈论这种情况。

我找到了一个reflect.NewAtat golang 文档,但老实说我不明白,而且我再次找不到适合我的情况的单一答案。

为了更好地理解......通过具有以下结构:

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}
}

但在我的例子中,多个结构可以到达这里,所以它作为一个接口到达:

var p interface{} = Counter{}

z := reflect.New(reflect.TypeOf(p))

for k := 0; k < z.NumMethod(); k++ {
   fmt.Println(z.Method(k)) // 0x47d150
}

但如图所示,它会打印内存地址。

我希望与0x47d150直接使用指针的输出相同。我在这里做错了什么?

4

1 回答 1

3

ya reflect.Type。类型上的方法Method等价于方法表达式

值为za reflect.Value。值上的方法Method等效于方法值

打印的表示是不同的,因为方法表达式和方法值不是一回事。

用于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}
}

接口中的具体值是一个非指针值。如果接口中的具体值是指针类型,则可以使用此代码:

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}
}
于 2019-03-29T04:54:57.017 回答