3 回答

TA贡献1911条经验 获得超7个赞
在您的示例中,您传递的是指针类型 ( *Ab)的值,而不是结构类型。
坚持 Type.Name()
如果它不是指针,Type.Name()将正确返回Ab。在指针的情况下,如果您仍然想要结构的名称,则可以使用Type.Elem()来获取元素的类型:
func getType(myvar interface{}) string {
if t := reflect.TypeOf(myvar); t.Kind() == reflect.Ptr {
return "*" + t.Elem().Name()
} else {
return t.Name()
}
}
测试它:
tst4 := Ab{}
tst5 := new(Ab)
fmt.Println(getType(tst4))
fmt.Println(getType(tst5))
输出(在Go Playground上尝试修改后的示例):
Ab
*Ab
笔记:
请注意,由于Type.Name()不解析指针,如果传递的值是指向指针的指针,则它将不起作用,例如**Ab,而 asType.String()自动解析指针,在这种情况下也将起作用。
我们也可以轻松地让我们的getType()函数使用**Ab(或使用任何深度的指针):
func getType(myvar interface{}) (res string) {
t := reflect.TypeOf(myvar)
for t.Kind() == reflect.Ptr {
t = t.Elem()
res += "*"
}
return res + t.Name()
}
用值调用它:
tst4 := Ab{}
tst5 := new(Ab)
tst6 := &tst5 // type of **Ab
tst7 := &tst6 // type of ***Ab
输出(在Go Playground上试试):
Ab
*Ab
**Ab
***Ab
使用 Type.String()
一个更简单更好的方法是使用它Type.String()代替Type.Name()which 自动处理指针并包括包名称。例如:
func getType(myvar interface{}) string {
return reflect.TypeOf(myvar).String()
}
对于修改后的示例,它输出:
string
int
float64
main.Ab
*main.Ab
在Go Playground上试试这个变体。

TA贡献1859条经验 获得超6个赞
fmt 也有一个很酷的%T标签
package main
import (
"fmt"
"net/http"
)
type Potato struct {
}
func main() {
fmt.Printf("I have a %T, an %T and a %T\n", Potato{}, http.StatusMultipleChoices, &http.Response{})
}
输出I have a main.Potato, an int and a *http.Response https://play.golang.org/p/6z7_0BSitm

TA贡献1877条经验 获得超1个赞
问题是new返回指针,下面应该得到想要的结果。
package main
import (
"fmt"
"reflect"
)
type Ab struct {
}
func getType(myvar interface{}) {
valueOf := reflect.ValueOf(myvar)
if valueOf.Type().Kind() == reflect.Ptr {
fmt.Println(reflect.Indirect(valueOf).Type().Name())
} else {
fmt.Println(valueOf.Type().Name())
}
}
func main() {
fmt.Println("Hello, playground")
tst := "string"
tst2 := 10
tst3 := 1.2
tst4 := new(Ab)
getType(tst)
getType(tst2)
getType(tst3)
getType(tst4)
}
输出是
Hello, playground
string
int
float64
Ab
- 3 回答
- 0 关注
- 207 浏览
添加回答
举报