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 중국어 웹사이트의 기타 관련 기사를 참조하세요!