cari
Rumahpembangunan bahagian belakangGolangMengapakah Penukaran float64 kepada int dalam Go Menghasilkan Keputusan Yang Tidak Dijangka?

Why Does Converting float64 to int in Go Produce Unexpected Results?

Ralat Menukar float64 kepada int dalam Go

Pengenalan

Menukar nombor titik terapung (float64) kepada integer (int) dalam Go boleh membawa kepada keputusan yang tidak dijangka disebabkan oleh had titik terapung perwakilan.

Memahami Masalah

Nombor perpuluhan seperti 100.55 tidak boleh diwakili dengan tepat menggunakan bilangan bit terhingga dalam binari, perwakilan dalaman yang digunakan oleh komputer. Nilai Float64 dalam Go mematuhi piawaian IEEE-754, yang menggunakan 53 bit untuk bahagian pecahan. Ini bermakna 100.55 dianggarkan kepada nombor perduaan boleh diwakili terdekat, yang membawa kepada sedikit percanggahan.

Contoh

Pertimbangkan kod berikut:

package main

import "fmt"

func main() {
    x := 100.55
    fmt.Println(x - float64(int(x)))
}

Menjalankan kod ini akan mencetak :

0.5499999999999972

bukan yang diharapkan 0.55.

Penyelesaian

Pemformat Rentetan (fmt.Printf)

Satu cara untuk mengendalikan percanggahan ini ialah dengan membundarkan nombor titik terapung kepada ketepatan yang dikehendaki sebelum mencetak.

package main

import "fmt"

func main() {
    x := 100.55
    fmt.Printf("%.2f\n", x)
}

Kod ini cetakan:

0.55

Perwakilan Bukan Titik Terapung

Pendekatan lain ialah mengelak daripada menggunakan nombor titik terapung sama sekali. Contohnya, untuk mewakili jumlah dolar, anda boleh menggunakan sen sebagai integer dan skala sebanyak 100 apabila dipaparkan.

cents := 10055
fmt.Printf("%d.%d $\n", cents/100, cents%100)

Kod ini mencetak:

100.55 $

Atas ialah kandungan terperinci Mengapakah Penukaran float64 kepada int dalam Go Menghasilkan Keputusan Yang Tidak Dijangka?. 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
Melaksanakan mutexes dan kunci dalam GO untuk keselamatan benangMelaksanakan mutexes dan kunci dalam GO untuk keselamatan benangMay 05, 2025 am 12:18 AM

Di GO, menggunakan mutexes dan kunci adalah kunci untuk memastikan keselamatan benang. 1) Gunakan sync.mutex untuk akses eksklusif yang saling eksklusif, 2) Gunakan sync.rwmutex untuk operasi membaca dan menulis, 3) Gunakan operasi atom untuk pengoptimuman prestasi. Menguasai alat ini dan kemahiran penggunaannya adalah penting untuk menulis program serentak yang cekap dan boleh dipercayai.

Penandaarasan dan Kod Go SerentakPenandaarasan dan Kod Go SerentakMay 05, 2025 am 12:18 AM

Bagaimana untuk mengoptimumkan prestasi kod go serentak? Gunakan alat terbina dalam GO seperti Getest, GOBENCH, dan PPROF untuk penandaarasan dan analisis prestasi. 1) Gunakan pakej ujian untuk menulis tanda aras untuk menilai kelajuan pelaksanaan fungsi serentak. 2) Gunakan alat PPROF untuk melakukan analisis prestasi dan mengenal pasti kesesakan dalam program ini. 3) Laraskan tetapan pengumpulan sampah untuk mengurangkan kesannya terhadap prestasi. 4) Mengoptimumkan operasi saluran dan hadkan bilangan goroutin untuk meningkatkan kecekapan. Melalui analisis penandaarasan dan prestasi yang berterusan, prestasi kod GO serentak dapat diperbaiki dengan berkesan.

Pengendalian ralat dalam program GO serentak: Menghindari perangkap biasaPengendalian ralat dalam program GO serentak: Menghindari perangkap biasaMay 05, 2025 am 12:17 AM

Kaedah untuk mengelakkan perangkap yang biasa pengendalian kesilapan dalam program GO serentak termasuk: 1. Memastikan penyebaran ralat, 2. Masa tamat pemprosesan, 3. Kesilapan agregasi, 4. Pengurusan Konteks Pengurusan, 5. Kesilapan membungkus, 6. Pembalakan, 7. Ujian. Strategi ini membantu mengendalikan kesilapan secara berkesan dalam persekitaran serentak.

Pelaksanaan antara muka yang tersirat di GO: Kekuatan menaip itikPelaksanaan antara muka yang tersirat di GO: Kekuatan menaip itikMay 05, 2025 am 12:14 AM

ImplisitInterfaceImplementationingoembodiesducktypingbyallowingtypestosatisfyinterfaceswithoutexplicitdeclaration.1) itpromotesflexabilityandmodularitybyfocusingonbehavior.2)

Pergi pengendalian ralat: Amalan dan corak terbaikPergi pengendalian ralat: Amalan dan corak terbaikMay 04, 2025 am 12:19 AM

Dalam pengaturcaraan GO, cara untuk menguruskan kesilapan secara berkesan termasuk: 1) menggunakan nilai ralat dan bukannya pengecualian, 2) menggunakan teknik pembalut ralat, 3) menentukan jenis ralat tersuai, 4) menggunakan semula nilai ralat untuk prestasi, 5) menggunakan panik dan pemulihan dengan berhati-hati, memastikan mesej ralat, 7) Amalan dan corak ini membantu menulis kod yang lebih mantap, boleh dipelihara dan cekap.

Bagaimana anda melaksanakan kesesuaian dalam perjalanan?Bagaimana anda melaksanakan kesesuaian dalam perjalanan?May 04, 2025 am 12:13 AM

Melaksanakan kesesuaian dalam GO boleh dicapai dengan menggunakan goroutin dan saluran. 1) Gunakan goroutin untuk melaksanakan tugas selari, seperti menikmati muzik dan memerhati rakan -rakan pada masa yang sama dalam contoh. 2) Memindahkan data dengan selamat antara goroutin melalui saluran, seperti model pengeluar dan pengguna. 3) Elakkan penggunaan goroutine dan kebuntuan yang berlebihan, dan reka bentuk sistem dengan munasabah untuk mengoptimumkan program serentak.

Membina struktur data serentak di GOMembina struktur data serentak di GOMay 04, 2025 am 12:09 AM

Gooffersmultipleapproachesforbuildingconcurrentdatastructures, termasukmutexes, saluran, andatomicoperations.1) mutexesprovidesimpleThreadsafetybutcancaPanperformanceBottlenecks.2) channelsoferscalabilitybutmayblockiffullorpty.

Membandingkan pengendalian ralat Go ke bahasa pengaturcaraan lainMembandingkan pengendalian ralat Go ke bahasa pengaturcaraan lainMay 04, 2025 am 12:09 AM

Go'serrorhandlingisexplicit, TreatingerRorSasReturnedValuesRatheHanexceptions, unsikepythonandjava.1) Go'sapproachensureSerrorawarenessbutcanleadtoverbosecode.2)

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.