Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk melakukan penukaran integer di Golang

Bagaimana untuk melakukan penukaran integer di Golang

PHPz
PHPzasal
2023-04-25 18:28:44939semak imbas

Apabila menulis kod, kita selalunya perlu menukar jenis data. Penukaran ini biasanya antara jenis data yang berbeza, seperti menukar rentetan kepada integer atau nombor titik terapung, atau menukar integer kepada rentetan, dsb. Di Golang, penukaran integer amat penting. Artikel ini akan memperkenalkan cara melakukan penukaran integer di Golang dan langkah berjaga-jaga yang berkaitan.

Golang menyokong penukaran jenis integer pelbagai saiz antara satu sama lain. Sebagai contoh, anda boleh menukar uint8 kepada int8 dan int64 kepada uint8. Walau bagaimanapun, perlu diingatkan bahawa penukaran jenis hanya boleh dilakukan apabila julat perwakilan jenis sasaran boleh sepenuhnya merangkumi julat nilai nilai ditukar.

Contohnya, jika anda menukar nilai maksimum int16 (32767) kepada int8, ia akan menyebabkan limpahan data dan hasilnya mungkin menjadi negatif. Begitu juga, jika anda menukar literal angka terapung 123.45 (yang ditafsirkan sebagai jenis float64) kepada uint16, anda kehilangan bahagian pecahan dan mendapat nilai integer terpenggal.

Berikut ialah beberapa contoh yang menunjukkan cara melakukan penukaran integer dalam Golang:

package main

import (
    "fmt"
    "math"
)

func main() {
    // 将int转换为float
    a := 10
    b := float64(a)
    fmt.Printf("a=%d, b=%f\n", a, b)

    // 将float转换为int
    c := 3.14159
    d := int(c)
    fmt.Printf("c=%f, d=%d\n", c, d)

    // 将uint64转换为int32
    const maxUint64 = math.MaxUint64
    var e uint64 = maxUint64
    f := int32(e)
    fmt.Printf("e=%d, f=%d\n", e, f)

    // 将int8转换为uint8
    var g int8 = -12
    h := uint8(g)
    fmt.Printf("g=%d, h=%d\n", g, h)
}

Dalam contoh di atas, kami menukar pembolehubah a daripada jenis int kepada float64 masing-masing, Tukar pembolehubah c daripada jenis float64 untuk menaip int, pembolehubah e jenis uint64 kepada int32, dan pembolehubah g jenis int8 kepada uint8. Dalam setiap kes, kami mencetak nilai awal dan hasil yang ditukar. Ambil perhatian bahawa julat jenis integer yang tidak ditandatangani (seperti uint8, uint16, dll.) harus dipertimbangkan dengan teliti sebelum menukarnya kepada jenis yang ditandatangani. Jika nilai asal melebihi julat perwakilan positif jenis sasaran, hasilnya akan menjadi negatif.

Selain penukaran eksplisit, Golang juga menyediakan beberapa penukaran integer tersirat. Dalam sesetengah kes, melakukan penukaran tersirat boleh menjadikan kod anda lebih bersih, tetapi dalam kes lain, anda perlu berhati-hati.

Sebagai contoh, apabila menggunakan pembolehubah jenis integer yang ditandatangani (cth. int8) dengan beberapa jenis integer yang tidak ditandatangani (cth. uint8) untuk penambahan, penolakan, pendaraban atau anjakan kiri, yang terakhir akan ditukar kepada DAN The jenis yang ditandatangani sama seperti yang pertama. Transformasi ini boleh menjadikan kod lebih mudah dibaca dan juga menghalang limpahan. Walau bagaimanapun, apabila menggunakan mana-mana pengendali lain, arahan penukaran mesti dikeluarkan secara eksplisit.

Di Golang, terdapat beberapa "peraturan tersirat" untuk penukaran integer. Contohnya, apabila menggunakan operator untuk menambah atau menolak dua jenis integer dengan saiz yang berbeza, Golang akan menukarnya secara automatik kepada jenis yang sama dan tanda-lanjutkan jika perlu. Walau bagaimanapun, apabila menetapkan jenis integer kepada pembolehubah jenis lain (seperti pada rentetan atau jenis antara muka), ia mesti ditukar secara eksplisit kepada jenis yang diperlukan.

Ringkasan:

  • Di Golang, nilai integer ​​boleh ditukar antara satu sama lain, tetapi julat jenis sasaran mestilah cukup besar untuk menampung julat nilai sumber .
  • Penukaran integer tersurat atau tersirat boleh digunakan, tetapi yang terakhir harus digunakan dengan berhati-hati untuk mengelakkan ralat penukaran yang tidak dijangka.
  • Apabila melakukan penukaran integer, anda perlu mempunyai pengetahuan asas matematik, terutamanya apabila mempertimbangkan sifat jenis integer yang ditandatangani dan tidak ditandatangani.

Atas ialah kandungan terperinci Bagaimana untuk melakukan penukaran integer di Golang. 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