Java의 정수 나누기 함정: 잘못된 결과 이해 및 해결
Java에서 정수 나누기를 수행할 때 분수 부분이 다음과 같은 일반적인 오류가 발생합니다. 결과가 폐기되어 예상치 못한 결과가 발생합니다. 이 문제는 기본 형식의 정수 나누기가 두 피연산자를 모두 정수로 처리한다는 사실에서 비롯됩니다.
예를 들어 다음 Java 코드를 고려하세요.
float res = quantity / standard;
수량이 표준인 경우 정수인 경우 나누기 연산은 정수 나누기를 수행하여 값이 잘립니다. 이는 정수 몫에 분수 부분이 없기 때문에 발생합니다.
이 문제를 해결하려면 분자나 분모를 부동 소수점 유형으로 명시적으로 변환해야 합니다. 이렇게 하면 나누기 연산이 결과의 소수 부분을 유지하는 부동 소수점 나누기를 수행하게 됩니다.
한 가지 접근 방식은 아래와 같이 분자를 부동 소수점으로 변환하는 것입니다.
float res = (float) quantity / standard;
또는 리터럴로 작업하는 경우 아래와 같이 분모에 "f" 접미사를 추가하여 적절한 부동 소수점 변환을 보장할 수 있습니다.
float f = 6800f / 500;
이러한 방법을 사용하면 나누기 작업이 부동 소수점 연산으로 수행되어 소수 부분을 보존하고 정수 나누기에서 발생하는 잘림 오류를 제거합니다.
위 내용은 Java의 정수 나누기가 잘린 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!