一個 integer 是集合 ℤ = {..., -2, -1, 0, 1, 2, ...} 中的一個數。
整數值可以使用十進制,十六進制,八進位或二進位表示,前面可以加上可選的符號(- 或 +)。
二進位表達的 integer 自 PHP 5.4.0 起可用。
要使用八進位表達,數字前必須加上 0(零)。要使用十六進位表達,數字前必須加上 0x。要使用二進位表達,數字前必須加上 0b。
Example #1 整數文字表達
<?php $a = 1234; // 十进制数 $a = -123; // 负数 $a = 0123; // 八进制数 (等于十进制 83) $a = 0x1A; // 十六进制数 (等于十进制 26) ?>
整數integer 的正式描述為:
decimal : [1-9][0-9 ]*
| 0
hexadecimal : 0[xX][0-9a-fA-F]+
#hexadecimal : 0[xX][0-9a-fA-F]+
octal : 0[0-7]+
## binary : 0b[01]+
integer : [+-]?decimal
| [+-]?hexadecimal
| [+-]?hexadecimal| [+-]?octal| [+-]? binary
整數型數的字長和平台有關,儘管通常最大值是大約二十億(32 位元有符號)。 64 位元平台下的最大值通常是大約 9E18。 PHP 不支援無符號整數。 Integer 值的字長可以用
常數PHP_INT_SIZE來表示,自 PHP 4.4.0 和 PHP 5.0.5後,最大值可以用常數 PHP_INT_MAX 來表示。
Warning
Example #2 八進制數的怪事<?php
var_dump(01090); // 八进制 010 = 十进制 8
?>
如果給定的一個數超出了integer 的範圍,將會被解釋為
float。同樣如果執行的運算結果超出了 integer 範圍,也會傳回 float。
Example #3 32 位元系統下的整數溢位<?php
$large_number = 2147483647;
var_dump($large_number); // int(2147483647)
$large_number = 2147483648;
var_dump($large_number); // float(2147483648)
$million = 1000000;
$large_number = 50000 * $million;
var_dump($large_number); // float(50000000000)
?>
<?php
$large_number = 9223372036854775807;
var_dump($large_number); // int(9223372036854775807)
$large_number = 9223372036854775808;
var_dump($large_number); // float(9.2233720368548E+18)
$million = 1000000;
$large_number = 50000000000000 * $million;
var_dump($large_number); // float(5.0E+19)
?>
可以更好地進行四捨五入。 <?php
var_dump(25/7); // float(3.5714285714286)
var_dump((int) (25/7)); // int(3)
var_dump(round(25/7)); // float(4)
?>
要明確地將一個值轉換為 integer,用 (int) 或 (integer) 強制轉換。不過大多數情況下都不需要強制轉換,因為當運算符,函數或流程控制需要一個 integer 參數時,值會自動轉換。也可以透過函數 intval() 來將一個值轉換成整數型。
。
從
浮點型轉換
當從浮點數轉換成整數時,就會向下取整。
如果浮點數超出了整數範圍(32 位元平台下通常為+/- 2.15e+9 = 2^31,64 位元平台下通常為+/- 9.22e+18 = 2^63) ,則結果為未定義,因為沒有足夠的精度給出一個確切的整數結果。在此情況下沒有警告,甚至沒有任何通知!
Warning
###絕對不要強制將未知的分數轉換為 integer,有時會導致不可預料的結果。 ###<?php echo (int) ( (0.1+0.7) * 10 ); // 显示 7! ?>
以上是解析PHP資料類型之整型(Integer)的詳細內容。更多資訊請關注PHP中文網其他相關文章!