淺談golang類型斷言,失敗類型斷言返回值問題

失敗的類型斷言,返回的值為最近斷言類型的零值

代碼入下:

func main() {
 var data interface{} = "ehoo"
 if res, ok := data.(int); ok {
 fmt.Printf("int res:%d\n", res)
 } else if res, ok := data.(bool); ok {
 fmt.Printf("bool res:%b\n", res)
 } else {
 fmt.Printf("other res:%v\n", res) // 斷言類型的零值,結果:false
 }
}

補充:go語言interface{}類型斷言的舉例使用

在go語言裡經常會用到interface{}類型,它是類似於c語言中的void *類型,可以接受任意類型的參數。當我們的函數或者方法中有該參數時,要判斷具體的類型值再進行相應處理。

一般格式:返回值,bool變量:=interface{}變量.(要判斷的具體類型),這樣就是以某個具體類型來斷言,返回值就是這個具體類型的。

比如:v,b:=a.(string),這個就是假設a這個interface{}變量是string類型,而v這個返回值就是string類型的變量,至於是否假設成功,就看b是true或者false。

這樣,如要判斷多個類型的話,就要分別寫多個語句,v,b:=a.(string),v1,b1:=a.(int),v2,b2:=a.(float64)…因為每次的返回值v,v1,v2是不同的預言類型數值,有點麻煩。

而用switch .(type) case這樣語句,就省事多瞭,格式為:返回值:=interface{}變量.(type) case 具體某一類型: case 具體某一類型: ……

type Student struct {
 m_Addr string
 m_ID int
}
 
func (stu *Student) SetAddr(addr interface{}) (bool, error) {
 //這樣寫法:返回值,bool變量:=interface{}變量.(要判斷的具體類型),就是判斷是否為指定類型的值。
 v, b := addr.(string) //這樣就是斷言v是string類型的變量,隻能賦值給同類型的數值。
 if b {    //如是上邊要判斷的string類型,這裡會返回true
 stu.m_Addr = v
 return true, nil
 } else { //如不是判斷的string類型,會返回false,下面會返回錯誤信息
 return false, fmt.Errorf("不是string類型")
 }
}
func (stu *Student) SetStu(data ...interface{}) (bool, error) {
 for _, d := range data { //循環遍歷參數列表,忽略第一個參數索引
 /*這種寫法是一個一個類型判斷,在判斷多個類型時,比較麻煩,使用下面switch case就簡便多瞭
 var v, b = d.(string)
 if b {
 stu.m_Addr = v
 }
 var v1, b1 = d.(int)
 if b1 {
 stu.m_ID = v1
 }
 */
 switch v := d.(type) { //傳遞type類型,隻能在switch case語句使用,返回的v就是具體的值。
 case int: //在每一個case判斷具體類型,並對返回值v進行處理
 stu.m_ID = v
 case string:
 stu.m_Addr = v
 }
 }
 return true, nil
}

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

推薦閱讀: