|
 |
Целое это число из множества Z = {..., -2, -1, 0, 1, 2, ...}.
Смотрите также:
Целые произвольной длины / GMP,
Числа с плавающей точкой и
Произвольная точность / BCMath
Целые могут быть указаны в десятичной, шестнадцатеричной или
восьмеричной системе счисления, по желанию с предшествующим знаком (- или +).
Если вы используете восьмеричную систему счисления, вы должны
предварить число 0 (нулем), для использования
шестнадцатеричной системы нужно поставить перед числом 0x.
Пример 11-1. Целые
<?php
$a = 1234; $a = -123; $a = 0123; $a = 0x1A; ?>
|
|
Формально возможная структура целых такова:
Размер целого зависит от платформы, хотя, как правило,
максимальное значение около двух миллиардов
(это 32-битное знаковое). PHP не поддерживает беззнаковые целые.
Если вы определите число, превышающее пределы целого типа, оно будет
интерпретировано как число с плавающей точкой. Также, если вы
используете оператор, результатом работы которого будет число,
превышающее пределы целого, вместо него будет возвращено число с
плавающей точкой.
Внимание |
К сожалению, в PHP была ошибка, так что это не всегда верно
работает, когда используются отрицательные числа.
Например: когда вы умножаете -50000 *
$million, результатом будет
-429496728. Однако, если оба операнда
положительны, проблем не возникает.
Эта ошибка устранена в PHP 4.1.0.
|
в PHP не существует оператора деления целых.
Результатом 1/2 будет число с плавающей точкой
0.5. Вы можете привести значение к целому, что
всегда округляет его в меньшую сторону, либо использовать функцию
round().
Для несомненного преобразования значения в целое используйте приведение
типа (int) или (integer).
Однако в большинстве случаев вам нет необходимости использовать приведение типа,
поскольку значение будет автоматически преобразовано, если оператор, функция или
управляющая конструкция требует целый аргумент. Вы также можете преобразовать
значение в целое при помощи функции intval().
Смотрите также Манипуляции с типами.
FALSE преобразуется в
0 (ноль), а TRUE
- в 1 (единицу).
При преобразовании из числа с плавающей точкой в целое, число будет
округлено в сторону нуля.
Если число с плавающей точкой превышает пределы целого
(как правило, это +/- 2.15e+9 = 2^31),
результат будет неопределенным, так как целое не имеет достаточной
точности, чтобы вернуть верный результат. В этом случае не будет
выведено ни предупреждения, ни даже замечания!
Предостережение |
Для других типов поведение преобразования в целое не определено.
В настоящее время поведение такое же, как если бы значение
сперва было преобразовано в булев тип. Однако
не полагайтесь на это поведение, так
как он может измениться без предупреждения.
|
Целые
rickard_cedergren at yahoo dot com
27-Jan-2005 01:15
When doing large subtractions on 32 bit unsigned integers the result sometimes end up negative. My example script converts a IPv4 address represented as a 32 bit unsigned integer to a dotted quad (similar to ip2long()), and adds a "fix" to the operation.
/**************************
* int_oct($ip)
* Convert INTeger rep of IP to octal (dotted quad)
*/
function int_oct($ip) {
/* Set variable to float */
settype($ip, float);
/* FIX for silly PHP integer syndrome */
$fix = 0;
if($ip > 2147483647) $fix = 16777216;
if(is_numeric($ip)) {
return(sprintf("%u.%u.%u.%u",
$ip / 16777216,
(($ip % 16777216) + $fix) / 65536,
(($ip % 65536) + $fix / 256) / 256,
($ip % 256) + $fix / 256 / 256
)
);
}
else {
return('');
}
}
23-Dec-2003 10:18
Sometimes you need to parse an unsigned
32 bit integer. Here's a function I 've used:
function parse_unsigned_int($string) {
$x = (float)$string;
if ($x > (float)2147483647)
$x -= (float)"4294967296";
return (int)$x;
}
laercio at gcsnet dot com dot br
02-Nov-2002 05:02
Hi,
To easily solve this problem of math operations compile your PHP with --enable-bcmath and use its set of intruction:
bcadd, bccomp, bcdiv, bcmod, bcmul, bcpow, bcscale, bcsqrt, bcsub.
No more flotpoint problems.
The intruction can be found on this manual.
Laercio Fortes
tim at freeman dot little-possums dot net dot invalid
15-Jan-2002 12:20
> there is no risk of rounding errors when doing (int)(n1/n2).
This is not quite true. Although both n1 and n2 can be represented exactly in a float, their quotient often cannot be. It is not even guaranteed that for floating-point arithmetic, 6.0/3.0==2.0 exactly. The floating-point answer may be 1.999...etc, which would round down to 1.
| |