> 백엔드 개발 > Golang > Go에서 float64를 int로 변환하면 예상치 못한 결과가 나타나는 이유는 무엇입니까?

Go에서 float64를 int로 변환하면 예상치 못한 결과가 나타나는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-14 22:11:12
원래의
749명이 탐색했습니다.

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

Go에서 float64를 int로 변환하는 중 오류

소개

Go에서 부동 소수점 숫자(float64)를 정수(int)로 변환하면 다음과 같은 문제가 발생할 수 있습니다. 부동 소수점 표현의 한계로 인해 예상치 못한 결과가 발생했습니다.

이해하기 문제

100.55와 같은 소수는 컴퓨터에서 사용하는 내부 표현인 이진수의 유한한 비트 수를 사용하여 정확하게 표현할 수 없습니다. Go의 Float64 값은 소수 부분에 53비트를 사용하는 IEEE-754 표준을 따릅니다. 즉, 100.55는 표현 가능한 가장 가까운 이진수에 근접하므로 약간의 불일치가 발생합니다.

다음 코드를 고려하세요.

package main

import "fmt"

func main() {
    x := 100.55
    fmt.Println(x - float64(int(x)))
}
로그인 후 복사

이 코드를 실행하면 인쇄됩니다. :

0.5499999999999972
로그인 후 복사

예상했던 것과는 다르게 0.55.

해결책

문자열 포맷터(fmt.Printf)

이러한 불일치를 처리하는 한 가지 방법은 인쇄하기 전에 부동 소수점 숫자를 원하는 정밀도로 반올림하는 것입니다.

package main

import "fmt"

func main() {
    x := 100.55
    fmt.Printf("%.2f\n", x)
}
로그인 후 복사

이 코드는 인쇄:

0.55
로그인 후 복사

비부동 소수점 표현

또 다른 접근 방식은 부동 소수점 숫자를 모두 사용하지 않는 것입니다. 예를 들어 달러 금액을 표시하려면 센트를 정수로 사용하고 표시할 때 100 단위로 스케일링하면 됩니다.

cents := 10055
fmt.Printf("%d.%d $\n", cents/100, cents%100)
로그인 후 복사

이 코드는 다음을 인쇄합니다.

100.55 $
로그인 후 복사

위 내용은 Go에서 float64를 int로 변환하면 예상치 못한 결과가 나타나는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿