프로그래밍에서 정수 나누기는 놀라운 결과를 가져올 수 있습니다. 다음 예를 고려해보세요:
<code>PRINT @set1 PRINT @set2 SET @weight= @set1 / @set2; PRINT @weight</code>
set1 = 47
과 set2 = 638
을 이용하여 예상되는 결과는 0.073667712
이다. 대신 출력은 0
입니다. 이는 기본적으로 많은 프로그래밍 언어가 두 피연산자가 모두 정수인 경우 정수 나누기를 수행하기 때문에 발생합니다. 정수 나누기는 소수 부분을 버려 잘림 현상이 발생합니다.
예상된 부동 소수점 나누기를 달성하려면 다음 방법 중 하나를 사용하세요.
set1
및 set2
을 처음부터 부동 소수점 숫자로 정의:<code>DECLARE @set1 FLOAT, @set2 FLOAT; SET @weight= @set1 / @set2;</code>
set1
및 set2
을 부동 소수점으로 변환:<code>SET @weight= CAST(@set1 AS FLOAT) / CAST(@set2 AS FLOAT);</code>
두 방법 모두 정확한 부동 소수점 나누기를 보장하고 정수 잘림으로 인한 정밀도 손실을 방지합니다. 이렇게 하면 분수 값이 필요한 계산에 대해 올바른 소수점 결과가 나옵니다.
위 내용은 정수 나눗셈이 프로그래밍에서 예상치 못한 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!