> 백엔드 개발 > PHP 문제 > PHP float가 부정확한 이유와 이를 방지하는 방법에 대해 토론하세요.

PHP float가 부정확한 이유와 이를 방지하는 방법에 대해 토론하세요.

PHPz
풀어 주다: 2023-03-28 17:48:55
원래의
2064명이 탐색했습니다.

PHP(Hypertext Preprocessor)는 동적 웹 개발에 일반적으로 사용되는 인기 있는 오픈 소스 서버 측 프로그래밍 언어입니다.

PHP에서 float는 3.14와 같이 소수 부분으로 숫자를 나타내는 데 사용되는 데이터 유형입니다. 그러나 일부 PHP 개발자는 부동 소수점을 사용할 때 일부 부정확성이 발생한다는 사실을 발견했습니다.

이 글에서는 PHP float가 부정확한 이유와 float를 올바르게 사용하는 방법에 대해 설명합니다.

1. 부동 소수점이 정확하지 않은 이유

컴퓨터에서는 제한된 길이의 숫자만 표현할 수 있기 때문에 부동 소수점 숫자가 제한됩니다. 따라서 계산에 부동 소수점 숫자를 사용할 때 일부 부정확성이 발생할 수 있습니다.

예를 들어, PHP에서 다음 코드:

$a = 0.1;
$b = 0.2;
$c = $a + $b;
echo $c;
로그인 후 복사

는 출력이 0.3이 될 것으로 예상하지만 실제로 출력은 0.30000000000000004입니다.

0.1과 0.2는 컴퓨터에서 무한대라 정확하게 표현할 수 없기 때문입니다. 0.1+0.2를 계산할 때 컴퓨터는 두 개의 무한한 숫자를 더하는데, 그 결과는 몇 가지 근사치를 사용하여 표현되어야 하므로 결과가 부정확해집니다.

2. 부정확한 부동 소수점을 방지하는 방법

부동 소수점은 부정확하지만 일부 시나리오에서는 여전히 사용해야 합니다. 이때 개발자는 부정확성을 최대한 피하기 위해 다음 사항에 주의해야 합니다.

1. 부동 소수점의 직접 비교는 피하세요

부동 소수점은 표현이 다를 수 있으므로 부동 소수점을 직접 비교하면 예상치 못한 결과가 발생할 수 있습니다.

예:

$a = 0.1;
$b = 0.2;
$c = 0.3;
if ($a + $b == $c) {
    echo "equals";
} else {
    echo "not equals";
}
로그인 후 복사

$a+$b의 결과가 $c의 결과와 정확히 동일하지 않기 때문에 이 코드의 출력 결과는 "같지 않음"입니다.

비교가 필요한 경우 다음 방법을 사용할 수 있습니다.

$epsilon = 0.00001;
if (abs($a+$b-$c) < $epsilon) {
    echo "equals";
} else {
    echo "not equals";
}
로그인 후 복사

이러한 방식으로 "내결함성 값"을 사용하여 두 개의 부동 소수점이 동일한지 확인할 수 있습니다.

2. 라운드 함수를 사용하세요.

라운드 함수는 부동소수점을 지정된 소수 자릿수로 반올림할 수 있습니다. 이를 통해 부동 소수점 부정확성 문제를 어느 정도 수정할 수 있습니다.

예:

$a = 0.1;
$b = 0.2;
$c = $a + $b;
echo round($c, 1);  //输出0.3
로그인 후 복사

3. float 대신 정수를 사용하세요

정확한 계산이 필요한 경우 float 대신 정수를 사용할 수 있습니다. 예를 들어 통화 값을 센트로 변환하고 정수를 사용하여 계산을 수행한 다음 결과를 달러로 변환할 수 있습니다.

$price = 2.68;  //2.68元
$price_in_cents = intval($price * 100);  //268分
$discount = 20;  //20%
$final_price_in_cents = $price_in_cents * (100 - $discount) / 100;
$final_price = number_format($final_price_in_cents / 100, 2);  //最终价格,2位小数
로그인 후 복사

이렇게 하면 계산에 부동소수점을 사용할 때 부정확성을 피할 수 있습니다.

3. 요약

PHP에서는 컴퓨터가 무한 길이의 숫자를 정확하게 표현할 수 없기 때문에 부동 소수점은 정확하지 않습니다. 부동 소수점 부정확성의 영향을 피하기 위해 다음 조치를 취할 수 있습니다.

1. 부동 소수점을 직접 비교하지 말고 결함 허용 값을 사용하여 두 부동 소수점이 동일한지 확인합니다.
2.
3. 정확한 계산을 위해 부동소수점 대신 정수를 사용하세요.

물론 float를 사용할 때에는 프로그램의 정확성을 보장하기 위해 여러 상황을 고려하고 적절하게 처리해야 합니다.

위 내용은 PHP float가 부정확한 이유와 이를 방지하는 방법에 대해 토론하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿