정수 나누기: 예상치 못한 동작 이해
Java에서 정수 나누기는 두 정수 값 사이의 나누기를 수행하고 결과의 소수 부분을 버립니다. . 이 동작은 다음 코드에서 볼 수 있듯이 예상치 못한 결과로 이어질 수 있습니다.
int quantity = 6800; int standard = 500; float res = quantity / standard;
예상 결과: 13.6
실제 결과: 13.0
이 불일치에 대한 한 가지 설명은 다음과 같습니다. 수행되는 정수 나누기에서. 정수 나누기는 결과를 잘라내어 소수 부분이 손실됩니다. 올바른 결과를 얻으려면 나눗셈을 부동 소수점 나눗셈으로 처리해야 합니다.
이는 분자를 명시적으로 부동 소수점으로 캐스팅하여 수행할 수 있습니다.
float res = (float) quantity / standard;
또는 , 리터럴을 다루는 경우 분모에 'f' 접미사를 추가하여 float:
float res = 6800f / 500;
float-division을 사용하면 정수 나누기를 방지하고 결과의 소수 부분을 보존할 수 있습니다. 이 접근 방식은 예상 결과인 13.6을 지속적으로 산출합니다.
위 내용은 Java의 정수 나누기가 예상치 못한 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!