Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Cara melakukan penukaran jenis dalam bahasa go

Cara melakukan penukaran jenis dalam bahasa go

青灯夜游
青灯夜游asal
2022-01-21 11:29:177863semak imbas

Dalam bahasa Go, penukaran jenis digunakan untuk menukar pembolehubah satu jenis data kepada pembolehubah jenis lain Sintaks ialah "type_name(expression)"; "type_name" ialah nama jenis, "expression" is ungkapan dan merupakan nilai yang perlu ditukar.

Cara melakukan penukaran jenis dalam bahasa go

Persekitaran pengendalian tutorial ini: sistem Windows 10, GO 1.11.2, komputer thinkpad t480.

Penukaran jenis bahasa Go

Penukaran jenis digunakan untuk menukar pembolehubah satu jenis data kepada pembolehubah jenis lain. Format asas penukaran jenis bahasa Go adalah seperti berikut:

type_name(expression)

type_name ialah jenis dan ungkapan ialah ungkapan.

Contoh

Dalam contoh berikut, integer ditukar kepada jenis titik terapung, hasilnya dikira dan hasilnya ditetapkan kepada pembolehubah titik terapung:

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)
}

Hasil keluaran pelaksanaan contoh di atas ialah:

mean 的值为: 3.400000

Penukaran jenis hanya boleh berjaya apabila definisinya betul, contohnya, menukar daripada jenis dengan julat nilai yang lebih kecil kepada jenis dengan julat nilai yang lebih besar Jenis (tukar int16 kepada int32). Kehilangan ketepatan (pemangkasan) berlaku apabila menukar daripada jenis dengan julat yang lebih besar kepada jenis dengan julat yang lebih kecil (menukar int32 kepada int16 atau float32 kepada int).

Hanya pembolehubah jenis pendasar yang sama boleh ditukar antara satu sama lain (seperti menukar jenis int16 kepada jenis int32 Ralat kompilasi akan berlaku apabila pembolehubah jenis asas yang berbeza ditukar kepada satu sama lain (seperti menukar jenis bool kepada jenis 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))
}

Penerangan kod adalah seperti berikut:

  • Baris 11 hingga 14 mengeluarkan julat berangka beberapa jenis integer sepunya.

  • Baris 17, isytihar dan mulakan pembolehubah a daripada jenis int32.

  • Baris 19, gunakan kata kerja %x bagi fmt.Printf untuk mengeluarkan nilai dalam format perenambelasan Baris ini mengeluarkan nilai 32-bit sebelum penukaran.

  • Baris 22, tukar nilai a kepada jenis int16, iaitu, tukar daripada jenis integer bertanda 32-bit kepada jenis integer bertanda 16-bit Disebabkan julat nilai int16 jenis Julat nilai lebih kecil daripada jenis int32, jadi nilai akan dipotong (ketepatan hilang).

  • Baris 24, mengeluarkan nilai pembolehubah yang ditukar, iaitu nilai b, dan juga dicetak dalam perenambelasan dan perpuluhan.

  • Baris 27, math.Pi ialah pemalar bagi pakej matematik Ia tidak mempunyai jenis secara lalai Ia akan disimpulkan secara automatik berdasarkan jenis sebenar di mana ia dirujuk .Pi ditugaskan kepada pembolehubah c, jadi jenisnya ialah float32.

  • Barisan 29, tukar float32 kepada jenis int dan output.

Output kod adalah seperti berikut:

int8 range: -128 127
int16 range: -32768 32767
int32 range: -2147483648 2147483647
int64 range: -9223372036854775808 9223372036854775807
int32: 0x3e6f54ff 1047483647
int16: 0x54ff 21759
3

Menurut hasil output, julat integer bertanda 16-bit ialah -32768~32767, dan nilai pembolehubah a ialah 1047483647. dalam julat ini. Nilai perenambelasan sepadan 1047483647 ialah 0x3e6f54ff Selepas ditukar kepada jenis int16, panjang dipendekkan separuh, iaitu, ia dipotong separuh dalam perenambelasan dan menjadi 0x54ff, dan nilai perpuluhan yang sepadan ialah 21759.

Apabila nombor titik terapung ditukar kepada integer, bahagian perpuluhan akan dialih keluar dan hanya bahagian integer akan dikekalkan.

Pembelajaran yang disyorkan: Tutorial Golang

Atas ialah kandungan terperinci Cara melakukan penukaran jenis dalam bahasa go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn