访问golang / reflect中未导出的字段?
发布时间:2020-12-16 19:26:15  所属栏目:大数据  来源:网络整理 
            导读:有没有办法使用Reflect访问go 1.8中未导出的字段? 这似乎不再起作用: https://stackoverflow.com/a/17982725/555493 请注意,reflect.DeepEqual工作得很好(也就是说,它可以访问未导出的字段),但我无法做出该函数的正面或反面.这是一个go playarea,显示它在
                
                
                
            | 
 有没有办法使用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. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 
