>백엔드 개발 >Golang >Float를 사용하여 0으로 나누기에서 Go 컴파일러 오류가 발생하는 이유는 무엇입니까?

Float를 사용하여 0으로 나누기에서 Go 컴파일러 오류가 발생하는 이유는 무엇입니까?

DDD
DDD원래의
2024-10-31 17:39:021029검색

Why Does Go Compiler Error Out on Division by Zero with Floats?

Go 컴파일러 오류: Float Zero Division

Go에서 유한 부동 소수점을 0으로 나누려고 하면 컴파일 오류가 발생합니다. 특히 다음 예에 설명된 것처럼 두 개의 유한 부동 소수점 숫자를 나누면 일반적으로 무한대가 발생한다는 점을 고려하면 이 동작은 직관에 반하는 것처럼 보일 수 있습니다.

<code class="go">func main() {
  var y float64 = 0.0
  var x float64 = 4.0 / y
  fmt.Println(x)
}</code>

출력:

+Inf

그러나 , 유한 부동 소수점을 0으로 나누면 컴파일러가 트리거됩니다. 오류:

<code class="go">func main() {
  var x float64 = 4.0 / 0.0
  fmt.Println(x)
}</code>

출력:

prog.go:9:22: division by zero

컴파일러 오류 이유

이 동작은 가다. 숫자 상수를 IEEE754 부동 소수점 유형에 직접 매핑하는 대부분의 프로그래밍 언어와 달리 Go는 숫자 상수를 임의 정밀도의 정확한 값으로 처리합니다. 결과적으로 Go는 본질적으로 무한대 또는 음의 0을 저장할 수 없습니다.

이 디자인 선택은 다음 예에서 볼 수 있듯이 상수 계산에서 오버플로를 방지하는 측면에서 이점을 제공합니다.

<code class="go">var x float64 = 1e1000 / 1e999 // yes, this is 10</code>

무한대 표현을 위한 대안

특별히 무한대 값이 필요한 경우 다음을 사용할 수 있습니다. 양의 무한대를 나타내는 math.Inf(1) 함수 또는 음의 무한대를 나타내는 math.Inf(-1) 함수.

위 내용은 Float를 사용하여 0으로 나누기에서 Go 컴파일러 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.