PHP 정밀도 계산 문제
php 정밀도 계산 문제
PHP의 흥미로운 현상을 살펴보겠습니다. var_dump( intval(0.58 * 100) ) 이 코드가 어떤 결과를 출력할지 추측해 보세요.
출력 결과가 58
왜일까요? 이것은 모두 부동 소수점 연산으로 인해 발생합니다.
사실 이러한 결과는 언어 버그가 아니라 언어의 구현 원리와 관련이 있습니다. js의 모든 숫자는 정수를 포함하여 실제로는 모두 배정밀도(double) 유형인 Number로 통일됩니다.
그리고 PHP는 int와 float를 구별합니다. 어떤 언어를 사용하더라도 부동소수점 연산이 포함되는 한 비슷한 문제가 있으므로 사용 시 주의가 필요합니다.
예를 들어 64비트 길이(이중 정밀도)를 사용하는 부동 소수점 숫자는 1개의 부호 비트(E), 11개의 지수 비트(Q) 및 52개의 가수 비트(M)로 표시됩니다(총 64개).
Sign Bit: 가장 높은 비트는 데이터의 부호를 나타내며, 0은 양수, 1은 음수를 나타냅니다.
지수 비트: 2진법으로 데이터의 거듭제곱을 나타내며, 지수는 오프셋 코드로 표현됩니다.
가수: 데이터의 소수점 이하 유효 숫자를 나타냅니다.
여기서 핵심은 이진수 표현, 십진수 표현은 Baidu에서 검색할 수 있습니다. 여기서는 자세히 설명하지 않겠습니다. 우리가 이해해야 할 핵심은 이진 표현의 경우 0.58은 무한히 긴 값이라는 것입니다. 다음 숫자는 암시적 1)을 생략합니다..
0.58의 이진 표현은 기본적으로(52비트)입니다. 0010100011110101110000101000111101011100001010001111 0.57(52비트)의 이진 표현은 기본적으로 00100011110101입니다. 110000101000 1111010111000010100011110
그리고 둘의 이진수는 다음과 같습니다. 이 52비트로만 계산하면 다음과 같습니다.
0.58 -> 0.579999999999999960.57 -> 0.5699999999999999
0.58 * 100의 구체적인 부동 소수점 곱셈은 자세히 고려하지 않으므로 막연하게 살펴보겠습니다. 암산으로... 0.58 * 100 = 57.9999999 99
그러면 intval해 주세요. 당연히 57입니다...
이 문제의 핵심은 다음과 같습니다. 컴퓨터의 이진수 표현에서는 무한합니다."
PHP 부동 소수점 형식은 +-*%/를 수행하고 있습니다. 부정확성 문제가 있습니다
우리는 일반적으로 사용되는 다음과 같은 부동 소수점 연산의 부정확성 문제를 해결할 수 있습니다. 정밀도 함수:bcadd — 두 개의 고정밀도 숫자 더하기
bccomp — 두 개의 고정밀도 숫자 비교 숫자, -1, 0, 1
bcdiv — 두 개의 고정밀도 숫자 나누기
bcmod — 나머지 찾기 고정밀 숫자의
bcmul — 두 개의 고정밀 숫자 곱하기
bcpow — 고정밀 숫자 찾기 Power
bcpowmod — 고정밀 숫자의 거듭제곱을 찾고 정수론에서 매우 일반적으로 사용되는 모듈러스 찾기
bcscale — Linux의 "scale="에 해당하는 기본 소수점 수를 구성합니다. bc
bcsqrt — 고정밀 숫자의 제곱근 찾기
bcsub — 두 고정밀 숫자 빼기
위 내용은 PHP 정밀도 계산 문제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

기사는 PHP, 커버 단계, 보안 측정, 최적화 기술 및 Solutions의 일반적인 오류를 사용하여 데이터베이스에서 데이터 검색에 대해 논의합니다. 문자 수 : 159

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 CSRF 토큰, 동일한 사이트 쿠키 및 적절한 세션 관리를 포함하여 PHP의 CSRF 공격을 방지하는 전략에 대해 설명합니다.

이 기사는 MySQL 데이터베이스 상호 작용에 대한 PHP의 MySQLI_Query () 및 MySQLI_Fetch_Assoc () 함수에 대해 설명합니다. 그것은 그들의 역할, 차이점을 설명하고 그들의 사용의 실질적인 예를 제공합니다. 주요 논쟁은 USIN의 이점에 중점을 둡니다

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.
