确定 Go 中派生接口类型的种类
在 Go 中处理反射的复杂性可能具有挑战性,尤其是在处理派生接口时接口和原始类型。在本文中,我们将探讨如何确定实现接口但具有底层基元实现的类型的reflect.Kind。
问题来自以下代码片段:
type ID interface { myid() } type id string func (id) myid() {} func main() { id := ID(id("test")) fmt.Println(id) fmt.Println(reflect.TypeOf(id)) // How to get the kind to return "reflect.Interface" from the var "id"? fmt.Println(reflect.TypeOf(id).Kind()) }
在这个场景中,我们有一个名为 ID 的接口和一个名为 id 的字符串类型。然而,id类型的实现采用id字符串类型。目标是从id变量中检索reflect.Kind作为reflect.Interface。
解决方案
解决这个问题的关键在于理解反射如何处理接口价值观。当将值传递给reflect.TypeOf()时,它会自动包装在interface{}中。然而,为了保存类型信息,必须使用指向接口的指针。
通过定义一个指向 ID 接口的指针并将其传递给reflect.TypeOf(),我们可以使用 Elem( ) 来访问接口类型的实际类型描述符。
代码示例
以下代码片段演示了解决方案:
id := ID(id("test")) fmt.Println(id) t := reflect.TypeOf(&id).Elem() fmt.Println(t) fmt.Println(t.Kind())
此代码将输出:
test main.ID interface
通过利用此技术,我们可以准确确定派生接口类型的reflect.Kind并揭示其底层实现细节。
以上是Go 中如何确定派生接口类型的'reflect.Kind”?的详细内容。更多信息请关注PHP中文网其他相关文章!