在go語言中,型別轉換用於將一種資料型別的變數轉換為另外一種型別的變數,語法為「type_name(expression)」;「type_name」為型別名,「expression」為表示式,是需要進行資料轉換的值。
本教學操作環境:windows10系統、GO 1.11.2、thinkpad t480電腦。
Go 語言型別轉換
型別轉換用於將一種資料型別的變數轉換為另外一種型別的變數。Go 語言型別轉換基本格式如下:
type_name(expression)
type_name 為型別,expression 為表示式。
範例
以下範例中將整型轉化為浮點型,並計算結果,將結果賦值給浮點型變數:
package main import "fmt" func main() { var sum int = 17 var count int = 5 var mean float32 mean = float32(sum)/float32(count) fmt.Printf("mean 的值為: %f\n",mean) }
以上範例執行輸出結果為:
mean 的值為: 3.400000
型別轉換只能在定義正確的情況下轉換成功,例如從一個取值範圍較小的型別轉換到一個取值範圍較大的型別(將 int16 轉換為 int32)。當從一個取值範圍較大的型別轉換到取值範圍較小的型別時(將 int32 轉換為 int16 或將 float32 轉換為 int),會發生精度丟失(截斷)的情況。
只有相同底層型別的變數之間可以進行相互轉換(如將 int16 型別轉換成 int32 型別),不同底層型別的變數相互轉換時會引發編譯錯誤(如將 bool 型別轉換為 int 型別):
package main import ( "fmt" "math" ) func main() { // 輸出各數值範圍 fmt.Println("int8 range:", math.MinInt8, math.MaxInt8) fmt.Println("int16 range:", math.MinInt16, math.MaxInt16) fmt.Println("int32 range:", math.MinInt32, math.MaxInt32) fmt.Println("int64 range:", math.MinInt64, math.MaxInt64) // 初始化一個32位元整型值 var a int32 = 1047483647 // 輸出變數的十六進位制形式和十進位制值 fmt.Printf("int32: 0x%x %d\n", a, a) // 將a變數數值轉換為十六進位制, 發生數值截斷 b := int16(a) // 輸出變數的十六進位制形式和十進位制值 fmt.Printf("int16: 0x%x %d\n", b, b) // 將常數儲存為float32型別 var c float32 = math.Pi // 轉換為int型別, 浮點發生精度丟失 fmt.Println(int(c)) }
程式碼說明如下:
第 11~14 行,輸出幾個常見整型型別的數值範圍。
第 17 行,宣告 int32 型別的變數 a 並初始化。
第 19 行,使用 fmt.Printf 的%x動詞將數值以十六進位制格式輸出,這一行輸出 a 在轉換前的 32 位的值。
第 22 行,將 a 的值轉換為 int16 型別,也就是從 32 位有符號整型轉換為 16 位有符號整型,由於 int16 型別的取值範圍比 int32 型別的取值範圍小,因此數值會進行截斷(精度丟失)。
第 24 行,輸出轉換後的 a 變數值,也就是 b 的值,同樣以十六進位制和十進位制兩種方式進行列印。
第 27 行,math.Pi 是 math 包的常數,預設沒有型別,會在參照到的地方自動根據實際型別進行推導,這裡 math.Pi 被賦值到變數 c 中,因此型別為 float32。
第 29 行,將 float32 轉換為 int 型別並輸出。
程式碼輸出如下:
int8 range: -128 127 int16 range: -32768 32767 int32 range: -2147483648 2147483647 int64 range: -9223372036854775808 9223372036854775807 int32: 0x3e6f54ff 1047483647 int16: 0x54ff 21759 3
根據輸出結果,16 位有符號整型的範圍是 -32768~32767,而變數 a 的值 1047483647 不在這個範圍內。1047483647 對應的十六進位製為 0x3e6f54ff,轉為 int16 型別後,長度縮短一半,也就是在十六進位制上砍掉一半,變成 0x54ff,對應的十進位制值為 21759。
浮點數在轉換為整型時,會將小數部分去掉,只保留整數部分。
推薦學習:
以上就是go語言怎麼進行型別轉換的詳細內容,更多請關注TW511.COM其它相關文章!