首頁 >後端開發 >Golang >go語言怎麼進行型別轉換

go語言怎麼進行型別轉換

青灯夜游
青灯夜游原創
2022-01-21 11:29:177929瀏覽

在go語言中,類型轉換用於將一種資料類型的變數轉換為另外一種類型的變量,語法為“type_name(expression)”;“type_name”為類型名,“expression”為表達式,是需要進行資料轉換的值。

go語言怎麼進行型別轉換

本教學操作環境: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。

浮點數在轉換為整數時,會將小數部分去掉,只保留整數部分。

推薦學習:Golang教學

以上是go語言怎麼進行型別轉換的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn