Golang中interface{}轉為數組的操作

interface{} 轉為普通類型

我們都知道在golang中interface{}可以代表任何類型,對於像int64、bool、string等這些簡單類型,interface{}類型轉為這些簡單類型時,直接使用

p, ok := t.(bool)
p, ok := t.(int64)

如果ok==true的話,就已經類型轉換成功。

假設有這樣一個場景,我們有一個函數有返回值,但是返回值的類型不定,所以我們的返回值類型隻能以接口來代替瞭。

返回接口類型之後,我們就要對其類型進行判斷然後進行類型轉換。如果返回的是數組的話,我們就不能像上面那樣直接進行轉換瞭。

那有什麼辦法呢?

可以考慮使用reflect.Typeof(mm).Kind()。

func generate() (interface{}, bool) {
	//s := []string{"123", "345", "abc"}
	//s := 123
	s := "mmm"
	return s, true
}
func test() {
	origin, ok := generate()
	if ok {
		switch reflect.TypeOf(origin).Kind() {
		case reflect.Slice, reflect.Array:
			s := reflect.ValueOf(origin)
			for i := 0; i < s.Len(); i++ {
				fmt.Println(s.Index(i))
			}
		case reflect.String:
			s := reflect.ValueOf(origin)
			fmt.Println(s.String(), "I am a string type variable.")
		case reflect.Int:
			s := reflect.ValueOf(origin)
			t := s.Int()
			fmt.Println(t, " I am a int type variable.")
		}
	}
}

generate()函數有兩個返回值,一個是接口類型,一個是bool類型。

我們隻對第一個參數進行處理,首先使用reflect.TypeOf(mm).Kind()獲得mm的類型,然後采用switch語句來判斷mm的類型,類型判斷完之後進入相應的case,然後通過reflect.ValueOf(mm)來mm的值取出來,如果mm本身是個數組的話,那麼s也是一個數組,就可以進行遍歷操作瞭。

總結

1、對於我們已知返回值是哪種類型的情況下,可以直接將返回值進行類型轉換,像上面那種轉為普通類型的方法一樣。

2、對於返回值類型不是已知的情況下,可以考慮使用reflect.TypeOf()的方式。

補充:golang interface{}轉換成struct結構體的兩種方法

1.使用斷言,強制轉換

 p, ok := (Value).(user)
     if ok {
         fmt.Println("id:" + p.Id)
         fmt.Println("name:" + p.Name)
     } else {
         fmt.Println("can not convert")
     }

2.json序列化

resByre,resByteErr:=json.Marshal(ResponseData)
 if resByteErr != nil {
  c.Data(utils.ErrorResult("讀取信息失敗" + resByteErr.Error()))
  return
 }
 var newData MnConfig
 jsonRes:=json.Unmarshal(resByre,&newData)
 if jsonRes != nil {
  c.Data(utils.ErrorResult("讀取信息失敗" + jsonRes.Error()))
  return
 }

實例:

package main 
import (
 "encoding/json"
 "fmt"
)
 
type user struct {
 Id int `json:"id"`
 Name string `json:"name"`
} 
 
func main() { 
 newUser:=user{
  Id:   1,
  Name: "杉杉",
 }
 
 var newInterface1 interface{}
 
 //第一種使用interface
 newInterface1=newUser
 fmt.Printf("使用interface: %v",newInterface1.(user))
 
 //第二種使用json
 var newInterface2 interface{}
 newInterface2=newUser
 resByre, resByteErr := json.Marshal(newInterface2)
 if resByteErr != nil {
  fmt.Printf("%v",resByteErr)
  return
 }
 var newData user
 jsonRes := json.Unmarshal(resByre, &newData)
 if jsonRes != nil {
  fmt.Printf("%v",jsonRes)
  return
 }
 fmt.Printf("使用 json: %v",newData)
 
}

結果:

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。

推薦閱讀: