PHP의 부동 소수 부정확성의 함정 탐색
부정확 한 부동 소수점 번호는 PHP에서 일반적인 문제입니다. 대답은 IEEE 754 이중 프리즈 형식을 사용하여 소수점 소수를 정확하게 표현할 수 없게한다는 것입니다. 1. 2. 부동 소수점 번호를 비교할 때는 abs ($ a - $ b)
부동 소수점 산술은 PHP 및 많은 프로그래밍 언어에서 혼란과 미묘한 버그의 일반적인 원천입니다. PHP는 숫자를 동적으로 처리하지만 IEEE 754 Double-Precision Floating-Point 형식의 기본 사용은 모든 소수점 숫자를 정확하게 표현할 수있는 것은 아닙니다 . 이는 특히 재무 계산이나 비교를 할 때 개발자를 놀라게 할 수있는 부정확성으로 이어집니다.

PHP의 부동 소수점 부정확성을 관리하기위한 주요 함정과 실질적인 전략을 살펴 보겠습니다.
1. 부동 소수점 숫자가 부정확 한 이유
컴퓨터는 바이너리에서 부동 소수점 수를 나타내지 만, 많은 소수점 분획 ( 0.1
또는 0.2
)에는 무한 이진 표현이 있습니다. 예를 들어:

$ a = 0.1 0.2; echo $ a; // 출력 : 0.3000000000000000004
이것은 PHP 버그가 아닙니다. 플로팅 포인트 수학이 하드웨어 수준에서 작동하는 방식입니다. 결과는 0.3
에 매우 가깝지만 정확히 0.3
아닙니다.
이것은 다음과 같습니다.

- 이진에서
0.1
반복 분율 (소수점에서 1/3)입니다. - 컴퓨터는 유한 한 메모리에 맞게 컴퓨터를 반올림해야합니다.
- 이러한 작은 반올림 오류는 산술 중에 축적됩니다.
2. 플로팅 점수를 비교하기 위해 ==
사용하지 마십시오
정밀한 오류로 인해 직접 평등 점검이 종종 실패합니다.
var_dump (0.1 0.2 == 0.3); // 거짓!
대신, 공차 (Epsilon)를 사용하여 두 개의 플로트가 "충분히 가깝다"는지 확인하십시오.
함수 float equessal ($ a, $ b, $ epsilon = 0.00001) { 복귀 복근 ($ a - $ b) <$ epsilon; } var_dump (float equestal (0.1 0.2, 0.3)); // 진실
필요한 정밀도를 기준으로 $epsilon
선택하십시오. 금융 앱의 경우 0.00001
조차도 너무 느슨 할 수 있습니다. 대신 정수 (예 : 센트)로 작업하는 것을 고려하십시오.
3. 재무 계산을위한 부동 소수점을 피하십시오
$10.99
와 같은 통화 값을 플로트로 저장하지 마십시오. 작은 반올림 오류조차도 총, 세금 또는 균형에서 불일치를 유발할 수 있습니다.
✅ 모범 사례 : 임의의 정밀 라이브러리가있는 정수 (센트) 또는 문자열 사용
// 센트로 저장하십시오 $ price1 = 1099; // $ 10.99 $ price2 = 250; // $ 2.50 $ 총 = $ price1 $ price2; // 1349 센트 = $ 13.49
또는 임의의 정밀도를 위해 PHP의 BC 수학 또는 GMP 확장을 사용하십시오.
// BC 수학 사용 echo bcadd ( '0.1', '0.2', 2); // '0.30' Echo bcmul ( '1.25', '3.10', 2); // '3.87'
BC 수학 기능은 숫자를 문자열로 취급하고 정확히 10 진수 산술을 수행합니다.
4. 정수로 변환 할 때 조심하십시오
수레를 정수 자 잘림으로 캐스팅하고 개선으로 인해 1-10의 오류가 발생할 수 있습니다.
$ float = 0.99 * 100; // 99 여야합니다 echo (int) $ float; // 98을 인쇄 할 수 있습니다!
왜? 0.99 * 100
98.99999999999999
로 평가할 수 있기 때문입니다.
✅ 수정 : 캐스팅 전 라운드
에코 (int) 라운드 (0.99 * 100); // 99
플로트를 정수로 변환 할 때 항상 round()
사용하십시오.
5. 문자열 서식 및 디스플레이를 조심하십시오
때로는 숫자가 충분히 정확하지만 형식화는 부동 소음을 노출시킵니다.
printf ( "%. 20f", 0.1 0.2); // 0.30000000000000000004441
number_format()
또는 sprintf()
사용하여 디스플레이를 위해 반올림합니다.
echo number_format (0.1 0.2, 2); // "0.30"
그러나 서식은 출력에만 영향을 미칩니다. 계산에서 기본 정밀 문제를 해결하지 않습니다.
모범 사례 요약
- financial 금융 수학에
bcadd()
,bcsub()
,bcmul()
,bcdiv()
사용하십시오. - float를 작은 공차와 비교하면
==
. - ✅ 가능하면 통화를 센트 (정수)로 저장합니다.
-
round()
- floating 플로팅 포인트 노이즈를 숨기려면
number_format()
가있는 형식 출력. - ploat 정확한 플로트 평등에 의존하지 마십시오.
플로팅 포인트 부정확성은 PHP에 고유하지 않지만이를 무시하면 실제 버그로 이어질 수 있습니다. 이진 부동 소수점의 한계를 이해하고 올바른 도구, 특히 BC 수학 및 정수 기반 산술을 사용하면 대부분의 함정을 피할 수 있습니다.
기본적으로 : 플로트가 돈을 다루지 말고 평등을 정확하게 믿지 마십시오 .
위 내용은 PHP의 부동 소수 부정확성의 함정 탐색의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

TosetupaPHPdevelopmentenvironmentonLinux,installPHPandrequiredextensions,setupawebserverlikeApacheorNginx,testwithaPHPfile,andoptionallyinstallMySQLandComposer.1.InstallPHPandextensionsviapackagemanager(e.g.,sudoaptinstallphpphp-mysqlphp-curlphp-mbst

두 개의 PHP 배열을 병합하고 고유 한 값을 유지하려면 두 가지 주요 방법이 있습니다. 1. 인덱스 어레이 또는 중복 제거의 경우 Array_Merge 및 Array_unique 조합을 사용하십시오. 먼저 Array_Merge ($ array1, $ array2)를 병합 한 다음 Array_Unique ()를 사용하여 모든 고유 한 값을 포함하는 새 배열을 가져옵니다. 2. 연관 배열 및 첫 번째 배열에서 키 값 쌍을 유지하려면 연산자를 사용하십시오. $ result = $ array1 $ array2는 첫 번째 배열의 키가 두 번째 배열에 의해 덮어 쓰지 않도록합니다. 이 두 가지 방법은 키 이름이 유지되는지 아니면 초점 만

비밀번호의 강도를 결정하려면 정기적이고 논리적 처리를 결합해야합니다. 기본 요구 사항은 다음과 같습니다. 1. 길이는 8 자리 이상입니다. 2. 적어도 소문자, 대문자 및 숫자를 포함합니다. 3. 특수 문자 제한을 추가 할 수 있습니다. 고급 측면의 관점에서, 문자의 지속적인 복제 및 증분/감소 시퀀스는 피해야하며, 이는 PHP 함수 감지가 필요합니다. 동시에, 블랙리스트를 소개하여 암호 및 123456과 같은 일반적인 약한 암호를 필터링해야합니다. 마지막으로 평가 정확도를 향상시키기 위해 ZXCVBN 라이브러리를 결합하는 것이 좋습니다.

PHP 파일 업로드를 안전하게 처리하려면 소스 및 유형을 확인하고 파일 이름 및 경로를 제어하고 서버 제한을 설정하고 미디어 파일을 두 번 처리해야합니다. 1. 토큰을 통한 CSRF를 방지하기 위해 업로드 소스를 확인하고 화이트리스트 제어를 사용하여 FINFO_FILE을 통해 실제 MIME 유형을 감지합니다. 2. 파일의 이름을 임의의 문자열로 바꾸고 감지 유형에 따라 비 WEB 디렉토리에 저장할 확장자를 결정하십시오. 3. PHP 구성 업로드 크기 및 임시 디렉토리 NGINX/APACHE는 업로드 디렉토리에 대한 액세스를 금지합니다. 4. GD 라이브러리는 잠재적 인 악성 데이터를 지우기 위해 그림을 다시 찾습니다.

PHP 변수 범위에 대한 일반적인 문제 및 솔루션에는 다음이 포함됩니다. 1. 기능 내에서 글로벌 변수에 액세스 할 수 없으며 글로벌 키워드 또는 매개 변수를 사용하여 전달해야합니다. 2. 정적 변수는 정적으로 선언되며 한 번만 초기화되며 값은 여러 통화 사이에 유지됩니다. 3. $ _get 및 $ _post와 같은 Hyperglobal 변수는 모든 범위에서 직접 사용할 수 있지만 안전한 필터링에주의를 기울여야합니다. 4. 익명 함수 사용 키워드를 통해 상위 범위 변수를 도입해야하며 외부 변수를 수정할 때는 참조를 전달해야합니다. 이러한 규칙을 마스터하면 오류를 피하고 코드 안정성을 향상시키는 데 도움이 될 수 있습니다.

PHP 주석 코드에는 세 가지 일반적인 방법이 있습니다. 1. // 또는 #을 사용하여 한 줄의 코드를 차단하며 // 사용하는 것이 좋습니다. 2. 사용 /.../ 여러 줄로 코드 블록을 랩핑하려면 중첩 할 수는 없지만 교차 할 수 있습니다. 3. 복합 기술 사용 / if () {} /와 같은 논리 블록을 제어하거나 편집기 바로 가기 키를 사용한 효율성을 향상시키기 위해서는 기호를 닫는 데주의를 기울이고 사용할 때 중첩을 피해야합니다.

PHP 의견을 작성하는 열쇠는 목적과 사양을 명확히하는 것입니다. 의견은 중복성이나 너무 단순성을 피하고 "수행 된 것"보다는 "왜"를 설명해야합니다. 1. 클래스 및 메소드 설명에 DocBlock (/*/)과 같은 통합 형식을 사용하여 가독성 및 도구 호환성을 향상시킵니다. 2. JS 점프가 수동으로 출력 해야하는 이유와 같은 논리의 이유를 강조합니다. 3. 복잡한 코드 전에 개요 설명을 추가하고 프로세스를 단계적으로 설명하고 전체 아이디어를 이해하는 데 도움이됩니다. 4. Todo 및 Fixme를 합리적으로 사용하여 할 일 항목과 문제를 표시하여 후속 추적 및 협업을 용이하게합니다. 주석이 양호하면 통신 비용을 줄이고 코드 유지 보수 효율성을 향상시킬 수 있습니다.

Ageneratorinphpisamemory- 효율적인 Way-Erate-Overgedatasetsetsbaluesoneatimeatimeatimeatimallatonce.1.generatorsuseTheyieldKeywordTocroadtOpvaluesondemand, RetingMemoryUsage.2
