PHP workshop for 2 days with Shopware, Sylius, PHPUnit and Codeception in Duisburg

bcsub

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

bcsub Вычитает одно число из другого с заданной точностью

Описание

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

Вычитает число num2 из num1.

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

num1

Левый операнд (уменьшаемое) в виде строки.

num2

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

scale

Этот необязательный параметр используется для установки количества знаков после десятичного разделителя в результате. Если не задано, то, по умолчанию, будет использовано значение заданное глобально с помощью bcscale(), либо 0.

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

Разность в виде строки.

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

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

Примеры

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

<?php

$a 
'1.234';
$b '5';

echo 
bcsub($a$b);     // -3
echo bcsub($a$b4);  // -3.7660

?>

Смотрите также

  • bcadd() - Сложить 2 числа произвольной точности

add a note add a note

User Contributed Notes 2 notes

up
5
nd at snackbox dot org
3 years ago
The parameter order here is probably fairly obvious to most people (subtract right from left), but to clarify with a simple use case since I was struggling with this at the end of a long day:

<?php
echo bcsub('7', '5'); // 7 - 5 = '2'
echo bcsub('12', '17'); // 12 - 17 = '-5'
?>

Provide the parameters in the same order you would when using a normal subtraction operator.
up
1
charles dot adrian dot wood at gmail dot com
2 years ago
Please note that bcsub will fail in non-obvious ways if it's fed something that cannot be converted to a number. For instance:

bcsub('yes', 'no') === '0'

Yes, if you put garbage in, you get garbage out. Just don't expect bcsub to throw an error when you feed it an entirely non-numeric value.
To Top