Для математических операций с числами произвольной точности PHP предлагает модуль BCMath.
Модуль поддерживает числа произвольного размера с точностью
до 2 147 483 647
, или 0x7FFFFFFF
, десятичных знаков,
если хватит памяти. Модуль представляет числа в виде строк.
Допустимые, или правильно сформированные, числа модуля BCMath —
строки, которые соответствуют регулярному выражению:
/^[+-]?[0-9]*(\.[0-9]*)?$/
.
Передача float-значений в функции модуля BCMath, которые ожидают строковый операнд, иногда даёт неожиданные результаты. Причина состоит в способе, которым PHP преобразовывает значения с плавающей точкой (float) в строки (string). В ряде преобразований возвращается числовая строка в экспоненциальной нотации или числовая строка с десятичным разделителем в виде запятой; до PHP 8.0.0 разделитель дробной части зависел от региональных настроек. Модуль BCMath не поддерживает экспоненциальную нотацию и работает только с десятичной точкой.
<?php
$num1 = 0; // (string) 0 => '0'
$num2 = -0.000005; // (string) -0.000005 => '-5.05E-6'
echo bcadd($num1, $num2, 6); // => '0.000000'
setlocale(LC_NUMERIC, 'de_DE'); // Десятичная запятая вместо точки
$num2 = 1.2; // (string) 1.2 => '1,2'
echo bcsub($num1, $num2, 1); // => '0.0'
?>