부동소수점 계산 결과 비교
부동소수점 계산의 예는 다음과 같습니다.
$a = 0.2+0.7;
$b = 0.9;
var_dump($a == $b);
인쇄된 결과는 bool(false)입니다. 즉, 여기서 0.2+0.7의 계산 결과는 0.9와 같지 않으며 이는 분명히 우리의 상식에 어긋납니다.
이 문제와 관련하여 공식 PHP 매뉴얼에는 다음과 같이 명시되어 있습니다. 0.2와 같은 단순한 소수는 약간의 정밀도를 잃지 않고 내부 바이너리 형식으로 변환할 수 없습니다. 이는 특정 소수를 유한한 자릿수로 정확하게 표현하는 것이 불가능하다는 사실과 관련이 있습니다. 예를 들어, 10진수 1/3은 0.3333333...이 됩니다.
위 변수를 배정밀도 형식으로 인쇄합니다.
$a = 0.2+0.7;
$b = 0.9;
printf("%0.20f", $a);
echo '
';
printf("%0.20f", $b);
출력 결과는 다음과 같습니다.
0.89999999999999991118
0.90000000000000002220
분명히 여기에서는 부동 소수점 데이터로서 정확도의 일부가 손실되었으며 완전히 정확할 수 없습니다. 따라서 부동 소수점 숫자 결과가 마지막 숫자까지 정확하다고 절대 신뢰하지 말고 두 개의 부동 소수점 숫자가 같은지 비교하지 마십시오. 이는 PHP의 문제가 아니라 컴퓨터 내부 부동 소수점 숫자 처리의 문제라는 점에 유의해야 합니다! C, JAVA 등의 언어에서도 동일한 문제가 발생합니다.
따라서 두 부동 소수점 숫자를 비교하려면 비교하기 전에 필요한 정밀도 범위 내에서 제어해야 하므로 bcadd() 함수를 사용하여 부동 소수점 숫자를 더하고 정밀도를 문자열로 변환합니다.
var_dump(bcadd(0.2,0.7,1) == 0.9); // 출력: bool(true)
부동소수점 반올림
"PHP 반올림 기능 천장 및 바닥" 기사에 다음 예가 있습니다.
echo ceil(2.1/0.7); // 출력: 4
?>
위의 부동 소수점 숫자 계산에 대한 논의를 통해 우리는 이것이 부정확한 부동 소수점 숫자 계산 결과로 인해 발생한다는 것을 알고 있습니다.
printf("%0.20f", (2.1/0.7)) // 출력: 3.00000000000000044409
?>
위에서 부동 소수점 수 계산에 대해 논의한 후에 이것이 부정확한 부동 소수점 수 계산 결과로 인해 발생한다는 것을 알았으므로 round() 함수를 사용하여 이를 처리할 수 있습니다.
echo ceil( round((2.1/0.7),1) );
?>
round() 함수는 지정된 정밀도에 따라 반올림하지만 소수점 한 자리를 유지해도 반올림 결과에는 영향을 미치지 않습니다.

PHP 是一门功能强大的编程语言,广泛应用于 Web 开发领域。其中一个非常常见的情况是需要将字符串转换为小数。这在进行数据处理的时候非常有用。在本文中,我们将介绍如何在 PHP 中将字符串转换为小数。

这篇文章将为大家详细讲解有关PHP浮点数四舍五入法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PHP浮点数四舍五入法概述浮点数在计算机中表示为小数点后跟指数,然而,它们通常以有限位数的近似值存储。当需要将浮点数四舍五入到特定精度时,有几种方法可以实现。方法1.round()函数round()函数将浮点数四舍五入为最接近的整数。它接受浮点数和可选的精度参数。例如:$num=1.55;echoround($num);//输出:2echoround($num,1)

使用strconv.FormatFloat函数将浮点数转换为字符串在Go语言中,我们经常需要将浮点数转换为字符串类型,用于输出或者存储等需求。Go语言中提供了strconv包,其中的FormatFloat函数可以将浮点数转换为字符串类型。FormatFloat函数有三个参数:f表示要转换的浮点数,fmt表示格式,以及prec表示要保留的小数位数。其中,f参数

随着计算机编程的发展,我们在日常编程工作中可能会遇到需要进行除法运算并取整的场景。而在PHP编程中,我们可以使用不同的方法来实现这个目的。

PHP作为一种流行的服务器端脚本语言,在进行浮点数计算时常常会遇到精度丢失或计算误差的问题,这些问题可能会对程序的准确性和稳定性造成影响。本文将探讨PHP浮点数计算误差的原因,并提出一些避免策略,同时给出具体的代码示例供参考。1.PHP浮点数计算误差的原因在计算机中,浮点数是以二进制形式表示的,而二进制并不能精确地表示所有的十进制小数,这就导致了浮点数的精

:一、BCMath简介BCMath是PHP内置的一个扩展库,专门用于处理大型整数和浮点数运算。它提供了丰富的函数来进行加、减、乘、除、平方、开方等各种数学运算,并且支持多种进制的数字表示。二、BCMath的优势BCMath相较于php原生提供的算术运算符和函数,主要有以下几个方面的优势:精度更高:BCMath的运算结果可以保留更多的有效数字,这对于涉及大数计算的场景尤为重要。范围更广:BCMath可以处理比PHP原生数据类型更大的数字,从而避免溢出或精度丢失的问题。功能更丰富:BCMath提供了

将字符串转换为浮点数是在PHP中常见的操作,可以通过内置的方法来实现。首先要确保字符串是合法的浮点数格式,才能成功地转换为浮点数。下面将详细介绍如何在PHP中将字符串转换为浮点数,并提供具体的代码示例。一、使用(float)强制转换在PHP中,将字符串转换为浮点数最简单的方式就是使用强制转换。强制转换的方式是在字符串前加上(float)即可,PHP会自动将其

使用C#中的Math.Round函数对浮点数进行四舍五入,需要具体代码示例在C#编程语言中,有时候我们需要对浮点数进行四舍五入操作。这时,我们可以使用Math.Round函数来实现此功能。Math.Round函数是C#中一个用于数学计算的内置函数,其主要功能是对指定的浮点数进行四舍五入。下面是Math.Round函数的常用格式:Math.Round(doub


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.
