Apabila cuba menukar rentetan perenambelasan (cth., "0xC40C5253") kepada nilai titik terapung menggunakan nilai strconv.ParseFalternative kaedah perlu diterokai.
Satu pendekatan melibatkan penggunaan fungsi strconv.ParseUint() untuk menghuraikan bait daripada perwakilan hex kepada integer 32-bit yang tidak ditandatangani (uint32). Ini adalah perlu kerana float32, yang biasa digunakan untuk mewakili nilai apungan dengan panjang 4-bait, memerlukan bait untuk ditafsirkan sedemikian.
Menggunakan pakej yang tidak selamat, bait boleh ditafsirkan semula sebagai nilai float32 dengan mencipta penunjuk kepada pembolehubah uint32 dan memberikannya kepada pembolehubah float32.
Pendekatan alternatif yang dicadangkan oleh JimB ialah menggunakan matematik fungsi terbina dalam pakej, math.Float32frombits(). Fungsi ini secara langsung menukar integer 32-bit yang tidak ditandatangani kepada nilai float32, menghapuskan keperluan untuk operasi penunjuk yang tidak selamat.
Berikut ialah coretan kod dikemas kini yang menunjukkan proses:
package main import ( "fmt" "strconv" "unsafe" ) func main() { s := "C40C5253" n, err := strconv.ParseUint(s, 16, 32) if err != nil { panic(err) } n2 := uint32(n) funsafe := *(*float32)(unsafe.Pointer(&n2)) fmt.Println(funsafe) fmath := math.Float32frombits(n2) fmt.Println(fmath) }
Atas ialah kandungan terperinci Bagaimana untuk Menukar Rentetan Perenambelasan kepada Nilai Float32 dengan Cekap dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!