有没有办法使用Reflect访问go 1.8中未导出的字段?
这似乎不再起作用: https://stackoverflow.com/a/17982725/555493
这似乎不再起作用: 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来访问它(读或写)字段,如下所示:
原文链接:https://www.f2er.com/go/186841.htmlrs := 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.