Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimanakah golang mewakili wang?

Bagaimanakah golang mewakili wang?

PHPz
PHPzasal
2023-05-10 11:35:071244semak imbas

Dalam golang, untuk mewakili wang kita boleh menggunakan float64 atau perpustakaan perpuluhan.

  1. Gunakan float64 untuk mewakili wang

Dalam golang, floating point jenis float64 adalah salah satu jenis berangka yang paling biasa digunakan, kita boleh menggunakannya untuk mewakili wang. Jika anda hanya perlu melakukan pengiraan dan perbandingan asas, menggunakan float64 adalah pilihan yang baik. Contohnya:

var price float64 = 19.99
var total float64 = price * 2
fmt.Println(total) // 39.98

Dalam contoh di atas, kami mengisytiharkan harga pembolehubah jenis float64 dan memulakannya kepada 19.99. Kemudian, kami mengira jumlah harga menggunakan harga * 2 dan menetapkan hasilnya kepada jumlah. Akhir sekali, kami mencetak nilai jumlah, iaitu 39.98.

Walau bagaimanapun, perlu diambil perhatian bahawa nombor titik terapung mempunyai isu ketepatan. Contohnya:

var price float64 = 0.1
var total float64 = price * 0.2
fmt.Println(total) // 0.020000000000000004

Dalam contoh di atas, kami mengisytiharkan harga pembolehubah jenis float64 dan memulakannya kepada 0.1. Kemudian, kami mengira jumlah harga menggunakan harga * 0.2 dan menetapkan hasilnya kepada jumlah. Akhir sekali, kami mencetak nilai jumlah dan hasilnya ialah 0.020000000000000004. Ini disebabkan oleh masalah ketepatan nombor titik terapung, jadi apabila berurusan dengan wang, adalah disyorkan untuk menggunakan perpustakaan perpuluhan dengan ketepatan yang lebih tinggi.

  1. Gunakan pustaka perpuluhan untuk mewakili wang

pustaka perpuluhan golang memberikan ketepatan yang lebih tinggi, yang boleh mengelakkan masalah ketepatan yang disebabkan oleh nombor titik terapung, dengan itu lebih baik Mewakili wang. Contohnya:

import "github.com/shopspring/decimal"

func main() {
    price := decimal.NewFromFloat(19.99)
    total := price.Mul(decimal.NewFromInt(2))
    fmt.Println(total) // 39.98
}

Dalam contoh di atas, kami menggunakan perpustakaan perpuluhan dan memetik kaedah Mul() untuk mengira jumlah harga. Kami juga menggunakan kaedah NewFromFloat() dan kaedah NewFromInt() untuk mencipta pembolehubah jenis perpuluhan. Nilai hasil adalah nilai perpuluhan, yang bersamaan dengan ketepatan berangka 10 kepada kuasa 24, jadi ketepatan boleh dijamin tidak terjejas.

Ringkasan

Dalam golang, kita boleh menggunakan float64 atau perpustakaan perpuluhan untuk mewakili wang. Jika anda hanya perlu melakukan pengiraan dan perbandingan asas, menggunakan float64 adalah pilihan yang baik. Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa nombor titik terapung mempunyai isu ketepatan. Jika ketepatan yang lebih tinggi diperlukan, maka menggunakan perpustakaan perpuluhan adalah pilihan yang lebih baik. Apabila berurusan dengan wang, beri perhatian khusus kepada isu ketepatan untuk mengelakkan ralat akibat isu ketepatan.

Atas ialah kandungan terperinci Bagaimanakah golang mewakili wang?. 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