本文實例講述了GO語言類型轉(zhuǎn)換和類型斷言的用法。分享給大家供大家參考。具體分析如下:
由于Go語言不允許隱式類型轉(zhuǎn)換。而類型轉(zhuǎn)換和類型斷言的本質(zhì),就是把一個類型轉(zhuǎn)換到另一個類型。
一、類型轉(zhuǎn)換
(1)、語法:結果類型> := 目標類型> ( 表達式> )
(2)、類型轉(zhuǎn)換是用來在不同但相互兼容的類型之間的相互轉(zhuǎn)換的方式,所以,當類型不兼容的時候,是無法轉(zhuǎn)換的。如下:
復制代碼 代碼如下:
func test4() {
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處運行會報錯。因為類型不兼容。注釋后,輸出如下:
復制代碼 代碼如下:
int->7
float32->7
int64->7
值得注意的是,如果某些類型可能引起誤會,應該用括號括起來轉(zhuǎn)換,如下:
復制代碼 代碼如下:
func test5() {
//創(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)換成另一種。
我們先來看一個最簡單的錯誤的類型斷言:
復制代碼 代碼如下:
func test6() {
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,就沒問題了。輸出為:
復制代碼 代碼如下:
int->99
以上是不安全的類型斷言。我們來看一下安全的類型斷言:
復制代碼 代碼如下:
func test6() {
var i interface{} = "TT"
j, b := i.(int)
if b {
fmt.Printf("%T->%d\n", j, j)
} else {
fmt.Println("類型不匹配")
}
}
輸出“類型不匹配”。
希望本文所述對大家的GO語言程序設計有所幫助。
您可能感興趣的文章:- 手把手教你導入Go語言第三方庫
- golang gopm get -g -v 無法獲取第三方庫的解決方案
- golang 輸出重定向:fmt Log,子進程Log,第三方庫logrus的詳解
- golang值類型轉(zhuǎn)換成[]uint8類型的操作
- go 類型轉(zhuǎn)換方式(interface 類型的轉(zhuǎn)換)
- Mongodb 利用mongoshell進行數(shù)據(jù)類型轉(zhuǎn)換的實現(xiàn)方法
- Go語言string,int,int64 ,float之間類型轉(zhuǎn)換方法
- Go 第三方庫之類型轉(zhuǎn)換問題