>Java >java지도 시간 >Java의 정수 나누기가 잘린 결과를 생성하는 이유는 무엇입니까?

Java의 정수 나누기가 잘린 결과를 생성하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-17 20:41:02995검색

Why Does Integer Division in Java Produce Truncated Results?

Java의 정수 나누기 함정: 잘못된 결과 이해 및 해결

Java에서 정수 나누기를 수행할 때 분수 부분이 다음과 같은 일반적인 오류가 발생합니다. 결과가 폐기되어 예상치 못한 결과가 발생합니다. 이 문제는 기본 형식의 정수 나누기가 두 피연산자를 모두 정수로 처리한다는 사실에서 비롯됩니다.

예를 들어 다음 Java 코드를 고려하세요.

float res = quantity / standard;

수량이 표준인 경우 정수인 경우 나누기 연산은 정수 나누기를 수행하여 값이 잘립니다. 이는 정수 몫에 분수 부분이 없기 때문에 발생합니다.

이 문제를 해결하려면 분자나 분모를 부동 소수점 유형으로 명시적으로 변환해야 합니다. 이렇게 하면 나누기 연산이 결과의 소수 부분을 유지하는 부동 소수점 나누기를 수행하게 됩니다.

한 가지 접근 방식은 아래와 같이 분자를 부동 소수점으로 변환하는 것입니다.

float res = (float) quantity / standard;

또는 리터럴로 작업하는 경우 아래와 같이 분모에 "f" 접미사를 추가하여 적절한 부동 소수점 변환을 보장할 수 있습니다.

float f = 6800f / 500;

이러한 방법을 사용하면 나누기 작업이 부동 소수점 연산으로 수행되어 소수 부분을 보존하고 정수 나누기에서 발생하는 잘림 오류를 제거합니다.

위 내용은 Java의 정수 나누기가 잘린 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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