|
Целые числаInteger - это число из множества ? = {..., -2, -1, 0, 1, 2, ...}. Смотрите также: СинтаксисЦелые числа могут быть указаны в десятичной (основание 10), шестнадцатеричной (основание 16), восьмеричной (основание 8) или двоичной (основание 2) системе счисления, с необязательным предшествующим знаком (- или +). Двоичная запись integer доступна начиная с PHP 5.4.0. Для записи в восьмеричной системе счисления, необходимо поставить пред числом 0 (ноль). Для записи в шестнадцатеричной системе счисления, необходимо поставить перед числом 0x. Для записи в двоичной системе счисления, необходимо поставить перед числом 0b Пример #1 Целые числа
<?php Формально, структуру целых чисел можно записать так: десятичные : [1-9][0-9]* | 0 шестнадцатеричные : 0[xX][0-9a-fA-F]+ восьмеричные : 0[0-7]+ двоичные : 0b[01]+ целые : [+-]?десятичные | [+-]?шестнадцатеричные | [+-]?восьмеричные | [+-]?двоичные Размер integer зависит от платформы, хотя, как правило, максимальное значение примерно равно 2 миллиардам (это 32-битное знаковое). 64-битные платформы обычно имеют максимальное значение около 9E18. PHP не поддерживает беззнаковые целые. С версии PHP 4.4.0 и PHP 5.0.5 размер integer может быть определен с помощью константы PHP_INT_SIZE, а его максимальное значение - с помощью константы PHP_INT_MAX. Внимание
Если в восьмеричном integer будет обнаружена неверная цифра (например, 8 или 9), оставшаяся часть числа будет проигнорирована. Пример #2 Странности с восьмеричными числами
<?php Переполнение целых чиселЕсли PHP обнаружил, что число превышает размер типа integer, он будет интерпретировать его в качестве float. Аналогично, если результат операции лежит за границами типа integer, он будет преобразован в float. Пример #3 Переполнение целых на 32-битных системах
<?php Пример #4 Переполнение целых на 64-битных системах
<?php В PHP не существует оператора деления целых чисел. Результатом 1/2 будет float 0.5. Если привести значение к integer, оно будет округлено вниз. Для большего контроля над округлением используйте функцию round().
<?php Преобразование в целоеДля явного преобразования в integer, используйте приведение (int) или (integer). Однако, в большинстве случаев, в приведении типа нет необходимости, так как значение будет автоматически преобразовано, если оператор, функция или управляющая структура требует аргумент типа integer. Значение также может быть преобразовано в integer с помощью функции intval(). Смотрите также: Манипуляции с типами. Из булевого типаFALSE преобразуется в 0 (ноль), а TRUE - в 1 (единицу). Из чисел с плавающей точкойПри преобразовании из float в integer, число будет округлено в сторону нуля. Если число с плавающей точкой превышает размеры integer (обычно +/- 2.15e+9 = 2^31 на 32-битных системах и +/- 9.22e+18 = 2^63 на 64-битных системах), результат будет неопределенным, так как float не имеет достаточной точности, чтобы вернуть верный результат. В этом случае не будет выведено ни предупреждения, ни даже замечания! Внимание
Никогда не приводите неизвестную дробь к integer, так как это иногда может дать неожиданные результаты.
<?php Смотрите более подробно: предупреждение о точности чисел с плавающей точкой. Из строкСмотрите Преобразование строк в числа Из других типовПредостережение
Для других типов поведение преобразования в integer не определено. Не полагайтесь на любое наблюдаемое поведение, так как оно может измениться без предупреждения. |
|