GO語言類型轉(zhuǎn)換和類型斷言實例分析
本文實例講述了GO語言類型轉(zhuǎn)換和類型斷言的用法。分享給大家供大家參考。具體分析如下:
由于Go語言不允許隱式類型轉(zhuǎn)換。而類型轉(zhuǎn)換和類型斷言的本質(zhì),就是把一個類型轉(zhuǎn)換到另一個類型。
一、類型轉(zhuǎn)換
(1)、語法:<結(jié)果類型> := <目標類型> ( <表達式> )
(2)、類型轉(zhuǎn)換是用來在不同但相互兼容的類型之間的相互轉(zhuǎn)換的方式,所以,當類型不兼容的時候,是無法轉(zhuǎn)換的。如下:
var var1 int = 7
fmt.Printf("%T->%v\n", var1, var1)
var2 := float32(var1)
var3 := int64(var1)
//var4 := []int8(var1)
//var5 := []string(var1)
fmt.Printf("%T->%v\n", var2, var2)
fmt.Printf("%T->%v\n", var3, var3)
//fmt.Printf("%T->%d", var4, var4)
//fmt.Printf("%T->%d", var5, var5)
}
其中,var4和var5處運行會報錯。因為類型不兼容。注釋后,輸出如下:
float32->7
int64->7
值得注意的是,如果某些類型可能引起誤會,應該用括號括起來轉(zhuǎn)換,如下:
//創(chuàng)建一個int變量,并獲得它的指針
var1 := new(int32)
fmt.Printf("%T->%v\n", var1, var1)
var2 := *int32(var1)
fmt.Printf("%T->%v\n", var2, var2)
}
*int32(var1)相當于*(int32(var1)),一個指針,當然不能直接轉(zhuǎn)換成一個int32類型,所以該表達式直接編譯錯誤。將該表達式改為 (*int32)(var1)就可以正常輸出了。
二、類型斷言
(1)語法:
<目標類型的值>,<布爾參數(shù)> := <表達式>.( 目標類型 ) // 安全類型斷言
<目標類型的值> := <表達式>.( 目標類型 ) //非安全類型斷言
(2)類型斷言的本質(zhì),跟類型轉(zhuǎn)換類似,都是類型之間進行轉(zhuǎn)換,不同之處在于,類型斷言實在接口之間進行,相當于Java中,對于一個對象,把一種接口的引用轉(zhuǎn)換成另一種。
我們先來看一個最簡單的錯誤的類型斷言:
var i interface{} = "kk"
j := i.(int)
fmt.Printf("%T->%d\n", j, j)
}
var i interface{} = "KK" 某種程度上相當于java中的,Object i = "KK";
現(xiàn)在把這個 i 轉(zhuǎn)換成 int 類型,系統(tǒng)內(nèi)部檢測到這種不匹配,就會調(diào)用內(nèi)置的panic()函數(shù),拋出一個異常。
改一下,把 i 的定義改為:var i interface{} = 99,就沒問題了。輸出為:
以上是不安全的類型斷言。我們來看一下安全的類型斷言:
var i interface{} = "TT"
j, b := i.(int)
if b {
fmt.Printf("%T->%d\n", j, j)
} else {
fmt.Println("類型不匹配")
}
}
輸出“類型不匹配”。
希望本文所述對大家的GO語言程序設計有所幫助。