访问golang / reflect中未导出的字段?

前端之家收集整理的这篇文章主要介绍了访问golang / reflect中未导出的字段?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有没有办法使用Reflect访问go 1.8中未导出的字段?
这似乎不再起作用: https://stackoverflow.com/a/17982725/555493

请注意,reflect.DeepEqual工作得很好(也就是说,它可以访问未导出的字段),但我无法做出该函数的正面或反面.这是一个go playarea,显示它在行动:https://play.golang.org/p/vyEvay6eVG.src代码如下

import (
"fmt"
"reflect"
)

type Foo struct {
  private string
}

func main() {
    x := Foo{"hello"}
    y := Foo{"goodbye"}
    z := Foo{"hello"}

    fmt.Println(reflect.DeepEqual(x,y)) //false
    fmt.Println(reflect.DeepEqual(x,z)) //true
}
如果struct是可寻址的,你可以使用unsafe.Pointer来访问它(读或写)字段,如下所示:
rs := reflect.ValueOf(&MyStruct).Elem()
rf := rs.Field(n)
// rf can't be read or set.
rf = reflect.NewAt(rf.Type(),unsafe.Pointer(rf.UnsafeAddr())).Elem()
// Now rf can be read and set.

See full example on the playground.

根据不安全包的文档,这个unsafe.Pointer的使用是“有效的”,并且干净地去检查.

如果结构不可寻址,这个技巧将不起作用,但你可以创建一个这样的可寻址副本:

rs = reflect.ValueOf(MyStruct)
rs2 := reflect.New(rs.Type()).Elem()
rs2.Set(rs)
rf = rs2.Field(0)
rf = reflect.NewAt(rf.Type(),unsafe.Pointer(rf.UnsafeAddr())).Elem()
// Now rf can be read.  Setting will succeed but only affects the temporary copy.

See full example on the playground.

猜你在找的Go相关文章