- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我对IsValid
函数很好奇,因为在我使用这个函数的过程中,它从来没有返回过false
。那么它什么时候返回否定结果呢?
最佳答案
作为文档 reflect.IsValid()
说:
It returns false if v is the zero Value. [...] Most functions and methods never return an invalid value. If one does, its documentation states the conditions explicitly.
Value.IsValid()
应该报告 reflect.Value
本身是否有效,而不是它包装的值(如果有的话)。
下面所有的例子都打印false
。您可以在 Go Playground 上试用它们.
最简单的示例是在 zero value 上调用 IsValid()
的 reflect.Value
(这是一个 struct
):
fmt.Println(reflect.Value{}.IsValid())
第二个最简单的例子是将 nil
传递给 reflect.ValueOf()
:
fmt.Println(reflect.ValueOf(nil).IsValid())
另一个例子:从一个指针开始是nil
,在这种情况下没有“指向”值,一个nil
指针指向任何地方。尝试使用 Value.Elem()
获取指向值的 reflect.Value
结果为零 reflect.Value
,其 IsValid()
方法将返回 false
:
var i *int
v := reflect.ValueOf(i)
v2 := v.Elem()
fmt.Println(v2.IsValid())
或者在一行中:
fmt.Println(reflect.ValueOf((*int)(nil)).Elem().IsValid())
如果你调用Value.Indirect()
也是一样的在上面的 reflect.Value()
上:
fmt.Println(reflect.Indirect(v).IsValid())
或尝试使用 Value.FieldByName()
按名称获取不存在的结构字段:
s := struct{}{}
fmt.Println(reflect.ValueOf(s).FieldByName("").IsValid())
或者尝试使用 Value.MethodByName()
按名称获取不存在的方法:
fmt.Println(reflect.ValueOf(s).MethodByName("").IsValid())
或尝试使用 Value.MapIndex()
通过不存在的键从映射中获取值:
m := map[int]int{}
fmt.Println(reflect.ValueOf(m).MapIndex(reflect.ValueOf(3)).IsValid())
列表还在继续......
关于go - reflect.IsValid 什么时候返回 false?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39011295/
我有: func NewMethodDescriptor(typ interface{}) *MethodDescriptor { reflectedMethod := reflect.Val
我需要确定地检查 reflect.Type 是否是一个错误。 错误没有反射(reflect)类型。在 go reflect 中检查类型错误的正式/惯用方式是什么? Go Playground Full
根据 reflect 文档 reflect.Value.MapIndex() 应返回一个 reflect.Value,它表示存储在 map 特定键处的数据的值.所以我的理解是以下两个表达式应该是相同的
与 reflect pkg 有点混淆 所有示例都使用 reflect.NewValue() 来获取 var 的 reflect.Value,但是 func NewValue 未记录在 http://g
在计算机语言的上下文中,我从未找到关于反射的词源的明确解释,所以我想在这里澄清一下。 “Reflection”源于拉丁语,有以下definitions : bend back turn back tu
我写了一个漂亮的函数,它可以接受 system.object ,反射(reflect)其属性并将对象序列化为 JSON 字符串。它看起来像这样: public class JSONSerializer
我正在尝试创建一个函数 import Language.Reflection foo : Type -> TT 我尝试使用reflect 策略: foo = proof { intro t
最近我和一位同事谈论 C++,感叹没有办法获取带有类字段名称的字符串并提取具有该名称的字段;换句话说,它缺乏反射(reflection)。他困惑地看着我,并问什么时候有人需要做这样的事情。 除了“嘿,
我正在考虑允许模块与属性文件中的类一起使用的想法;像 availableModules.properties Contact=org.addressbook.ContactMain Business=
这个问题特别与为具有大量字段的对象覆盖 equals() 方法有关。首先,让我说这个大对象不能在不违反 OO 原则的情况下分解成多个组件,所以告诉我“没有类应该有超过 x 个字段”无济于事。 继续前进
例子 router.Get(path, handler) // works fine methodStr = "Get" router.methodStr(path, handler) // e
我一直坚持使用反射库的问题。由于很多推荐,我决定使用它,但我只是在学习,有些部分并不是很容易.. 我有这部分代码: func countDataByName(sourceName string, s
我有一个包含一些 url 参数的特定结构,我想使用 reflect 构建一个 url 参数字符串以遍历结构字段,这样我就不会关心结构真正包含什么。 假设我有一个这样的结构: type Student
我正在尝试从 reflect.Value 中检索字符串值, 我希望 value.String()成为okok但我得到了相反。 我错过了什么吗? package main import ( "f
为了避免创建 org.reflections.Reflections 类的多个实例,我只想创建一个并根据需要重用。有谁知道这个类是否是线程安全的? 如果它不是线程安全的,我知道我可以使用 Java 的
我最近对引用、具体化和反射(reflection)感到困惑。有人可以很好地解释他们的关系和差异(如果有的话)吗? 最佳答案 引用 这可能是最简单的一个。考虑一下当您在 REPL 中键入以下内容时会发生
less main.go输出: ``` package main import ( "reflect" "net/url" "fmt" ) type User struct {
我在 golang 中使用 gorm 包 ( https://github.com/jinzhu/gorm ) 作为我的数据库库。我有很多类(数据库表),如“酒店”或“套餐”。复制代码不是好的编程习惯
我有代码 var t reflect.Type = LaunchController(route.controller) // create controller ptr . var
是否有可能以及如何在不从类型创建对象并调用它的情况下获取类型的 reflect.Type reflect.TypeOf(obj) Java 中的内容是:MyType.class 最佳答案 您可以使用以
我是一名优秀的程序员,十分优秀!