PHP 8.4.0 RC3 available for testing

bccomp

(PHP 4, PHP 5, PHP 7, PHP 8)

bccomp Сравнение двух чисел произвольной точности

Описание

bccomp(string $num1, string $num2, ?int $scale = null): int

Сравнивает num1 с num2 и возвращает целочисленный результат.

Список параметров

num1

Левый операнд в виде строки.

num2

Правый операнд в виде строки.

scale

Необязательный аргумент scale задаёт количество цифр после десятичной точки, которое будет участвовать в сравнении.

Возвращаемые значения

Возвращает 0, если числа равны; 1, если left_operand больше, чем right_operand; -1, если меньше.

Список изменений

Версия Описание
8.0.0 scale теперь допускает значение null.

Примеры

Пример #1 Пример использования bccomp()

<?php

echo bccomp('1', '2') . "\n"; // -1
echo bccomp('1.00001', '1', 3); // 0
echo bccomp('1.00001', '1', 5); // 1

?>
Добавить примечание

Примечания пользователей 3 notes

up
26
Robert Lozyniak
14 years ago
Beware that negative zero does not compare equal to positive zero.
up
15
aaugrin at gmail dot com
6 years ago
BEWARE! left and right operand is string!! so number in E-notation like 9.012E-6 need to be converted with sprintf('%F') to string
up
-1
m dot kaczanowski at alianet dot pl
15 years ago
Improvement of functions bcmax() and bcmin() originaly written by frank at booksku dot com

<?php

function bcmax() {
$args = func_get_args();
if (
count($args)==0) return false;
$max = $args[0];
foreach(
$args as $value) {
if (
bccomp($value, $max)==1) {
$max = $value;
}
}
return
$max;
}

function
bcmin() {
$args = func_get_args();
if (
count($args)==0) return false;
$min = $args[0];
foreach(
$args as $value) {
if (
bccomp($min, $value)==1) {
$min = $value;
}
}
return
$min;
}
?>
To Top