또 다른 토론에서는 정수를 0으로 나누었음에도 불구하고 C 코드에서 사용자가 "부동 소수점 오류"를 경험했습니다. 실제 문제가 되는 거죠. 이로 인해 정수 0으로 나누기 연산에서 부동 소수점 예외가 발생할 수 있는지에 대한 논쟁이 촉발되었습니다.
전통적으로 정수 0으로 나누기는 정수 예외(IA-32의 #DE 및 IA-32의 #DE)를 생성하는 것으로 간주되었습니다. AMD64), 부동 소수점 0으로 나누기는 부동 소수점 예외(인터럽트 16 또는 19)를 트리거합니다. 그러나 일부 플랫폼은 이 규칙에서 벗어납니다.
POSIX 표준에 따르면 정수 피연산자에 대한 0으로 나누기 연산은 다음을 나타내는 SIGFPE 신호를 생성해야 합니다. 부동 소수점 예외. 이는 POSIX 시스템에서 0으로 정수 나누기가 부동 소수점 예외로 보고된다는 의미입니다.
GNU C 라이브러리(glibc)를 사용하는 많은 Linux 시스템의 경우, SIGFPE는 siginfo_t 객체의 si_code 필드를 통해 추가 정보를 제공합니다. 0으로 정수 나누기의 경우 이 필드의 값은 FPE_INTDIV_TRAP입니다.
Windows에서 정수 0으로 나누기 예외를 처리하는 방법에 대한 정보는 쉽게 얻을 수 없습니다. Windows에서는 고유한 예외 유형을 사용하거나 다양한 산술 예외를 Unix와 유사한 단일 범주로 패키징할 수 있습니다.
정수 산술과 달리 IEEE754는 부동 소수점 표준은 0으로 나누기에 대한 특정 동작을 정의합니다. 연산:
In 대부분의 운영 체제 및 C ABI에서는 부동 소수점 예외가 사용자 공간 프로세스에 대해 기본적으로 마스크됩니다. 이를 통해 트랩을 발생시키지 않고 계산을 통해 오류 값(NaN 및 Inf)을 전파할 수 있습니다.
"고정" 정수 오버플로 플래그에 대한 제안이 만들어졌습니다. 계산 순서 중에 오버플로를 기록합니다. 그러나 정수 오버플로 감지 방법은 아키텍처에 따라 다르며 x86에서는 각 계산 후 조건부 분기가 필요하고 MIPS는 부호 있는 오버플로에 대한 트랩핑을 위한 특정 지침을 제공합니다.
정수 나누기 동작 0이고 부동 소수점 예외 처리는 플랫폼에 따라 다릅니다. 일부 시스템(예: POSIX 시스템)은 정수 0으로 나누기를 부동 소수점 예외로 처리하지만 다른 시스템에서는 이를 구별할 수 있습니다. 이러한 문제를 디버깅할 때 대상 플랫폼의 특정 오류 보고 메커니즘을 알고 있는 것이 중요합니다.
위 내용은 0으로 정수 나누기가 부동 소수점 예외를 트리거할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!