失敗的類型斷言,返回的值為最近斷言類型的零值
代碼入下:
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 { //循環(huán)遍歷參數列表,忽略第一個參數索引
/*這種寫法是一個一個類型判斷,在判斷多個類型時,比較麻煩,使用下面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
}
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- golang中bufio.SplitFunc的深入理解
- 通過匯編看golang函數的多返回值問題
- Golang的func參數及返回值操作