本篇內(nèi)容介紹了“go語(yǔ)言反射指的是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
目前成都創(chuàng)新互聯(lián)公司已為近1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站托管運(yùn)營(yíng)、企業(yè)網(wǎng)站設(shè)計(jì)、根河網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。Go 語(yǔ)言中的反射與其他語(yǔ)言有比較大的不同,Golang 中的發(fā)射主要涉及到兩個(gè)基本概念 Type 和 Value,它們也是 Go 語(yǔ)言包中 reflect 包 里最重要的兩個(gè)類型。
在 Golang 中對(duì)所有 接口 進(jìn)行反射,都可以得到一個(gè)包含 Type 和 Value 的信息結(jié)構(gòu)。顧名思義,Type 主要表達(dá)的是被反射的這個(gè)變量本身的類型信息,而 Value 則為該變量實(shí)例本身的信息。
Golang 中的反射主要有兩個(gè)作用,即,獲取類型信息和獲取值類型。
利用反射我們可以:
語(yǔ)法:
reflect.TypeOf(x)
作用:
獲取數(shù)據(jù)類型
用法:
package main
import (
"fmt"
"reflect"
)
func main() {
var x = 3.4
var str = "Hello World"
fmt.Println("x type =", reflect.TypeOf(x))
fmt.Println("str type =", reflect.TypeOf(str))
}
語(yǔ)法:
reflect.TypeOf(varname)
作用:
可以獲取該變量對(duì)應(yīng)的值。
用法:
package main
import (
"fmt"
"reflect"
)
func main() {
var x = 1024
var str = "Hello World"
fmt.Println("x type =", reflect.TypeOf(x))
fmt.Println("str type =", reflect.TypeOf(str))
}
語(yǔ)法:
reflect.TypeOf(varname).Kind()
作用:
使用 reflect.TypeOf 傳入我們要獲取的變量,即可以獲取該變量的類型,同時(shí)使用 Kind 方法可以獲取該類型的詳細(xì)信息
用法:
package main
import (
"fmt"
"reflect"
)
func main() {
var x = 1024
var str = "Hello World"
typeX := reflect.TypeOf(x)
typeStr := reflect.TypeOf(str)
typexKind := typeX.Kind()
typeStrKind := typeStr.Kind()
fmt.Println("x type =", typeX, ", Kind =", typexKind)
fmt.Println("str type =", typeStr, ", Kind =", typeStrKind)
}
語(yǔ)法:
reflect.ValueOf(varname)
作用:
使用 reflect.ValueOf 傳入我們要獲取的變量,可以獲取該變量的值信息
用法:
package main
import (
"fmt"
"reflect"
)
func main() {
var x = 1024
var str = "Hello World"
valueX := reflect.ValueOf(x)
valueStr := reflect.ValueOf(str)
fmt.Println("valueX =", valueX)
fmt.Println("valueStr =", valueStr)
}
語(yǔ)法:
reflect.ValueOf(varname).Elem()
作用:
使用 reflect.ValueOf 傳入我們要獲取的變量,可以獲取該變量的值信息
用法:
package main
import (
"fmt"
"reflect"
)
func main() {
var x = 1024
var str = "Hello World"
valueX := reflect.ValueOf(x)
valueStr := reflect.ValueOf(str)
fmt.Println("valueX =", valueX)
fmt.Println("valueStr =", valueStr)
valueElemX := valueX.Elem()
valueElemStr := valueStr.Elem()
fmt.Println("valueElemX =", valueElemX)
fmt.Println("valueElemStr =", valueElemStr)
}
語(yǔ)法:
personValue := reflect.ValueOf(p)
infoFunc := personValue.MethodByName("Info")
infoFunc.Call([]reflect.Value{})
作用:
通過 reflect.ValueOf 獲取結(jié)構(gòu)體的值信息,再次使用結(jié)構(gòu)體值信息的 MethodByName 獲取結(jié)構(gòu)體的方法,最后使用 Call 方法可以實(shí)現(xiàn)調(diào)用結(jié)構(gòu)體的方法
用法:
import (
"fmt"
"reflect"
)
type Student struct {
Name string
Age int
Score float64
}
func (s Student)Info(){
fmt.Println("Name =", s.Name, "Age =", s.Age, "Score =", s.Score)
}
func main() {
var p = Student{
Name:"Jim",
Age:10,
Score:99,
}
personValue := reflect.ValueOf(p)
infoFunc := personValue.MethodByName("Info")
infoFunc.Call([]reflect.Value{})
}
下面這段代碼使用了TypeOf,來處理結(jié)構(gòu)體里面包含的數(shù)組、時(shí)間類型的值??梢宰鳛橐粋€(gè)通用的反射方式使用.
func reflect(o interface{}) error {
re := reflect.TypeOf(o).Elem()
rv := reflect.ValueOf(o).Elem()
//判斷是否為結(jié)構(gòu)體
if re.Kind() == reflect.Struct {
for i := 0; i < re.NumField(); i++ {
f := re.Field(i)
name := f.Name
fmt.Printf("field name %v :" ,name)
//獲取結(jié)構(gòu)體其中一個(gè)字段的值
v := rv.FieldByName(name)
if v.Kind() == reflect.Struct {
//處理時(shí)間類型
if v.Type().ConvertibleTo(reflect.TypeOf(time.Time{})) {
fmt.Printf("field name : %v type of time" ,name)
continue
}
//判斷是否為空
if !v.IsNil() {
fmt.Printf("field name : %v is empty" ,name)
continue
}
//TODO 此處沒有業(yè)務(wù)邏輯可以補(bǔ)充
}
//處理數(shù)組類型
if v.Kind() == reflect.Slice {
for j := 0; j < v.Len(); j++ {
//判斷數(shù)組里面的對(duì)象是否為指針類型
if reflect.TypeOf(v.Index(j).Interface()).Kind() == reflect.Ptr {
fmt.Printf("field name : %v type of Ptr" ,name)
continue
}
}
}
}
}
return nil
}
“go語(yǔ)言反射指的是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!