PHP支持9种原始数据类型。php
4种标量类型:程序员
boolean
布尔型integer
整形float
浮点型(也称做double
)string
字符串3种复合类型:正则表达式
array
数组object
对象callable
可调用2种特殊类型数组
resource
资源null
无类型为了确保代码的易读性,咱们一般会使用一些伪类型:函数
mixed
混合类型number
数字类型callback
回调类型(又称为callable
)array|object
数组|对象类型void
无类型变量的类型不是程序员设定,是由PHP根据该变量使用的上下文在运行时决定的。测试
与变量类型有关的经常使用函数操作系统
var_dump()
函数。gettype()
函数。<?php $a = 1; if(is_int($a)){ echo "\r\n\$a是在整形\r\n"; } if(is_float($a)){ echo "\r\n\$a是在浮点型\r\n"; } if(is_string($a)){ echo "\r\n\$a是在字符串\r\n"; } ...... ?>
settype()
函数。这是最简单的类型。boolean
表达了真值,能够为TRUE
或 FALSE
code
要指定一个布尔值,使用常量TRUE
或 FALSE
。(不区分大小写)如:对象
<?php $bool = TRUE; // 设置$bool 为 TRUE ?>
一般运算符所返回的boolean
值结果会被传递给控制流程。资源
要明确的将一个值转换成boolean
,用(bool)
或者(boolean)
来强制转换,可是不少状况下不须要用强制转换,由于当运算符,函数或者流程控制结构须要一个 boolean
参数时,该值会被自动转换。
当转换为 boolean 时,如下值被认为是 FALSE:
FALSE
自己NULL
(包括还没有赋值的变量)全部其它值都被认为是TRUE
(包括任何资源和NAN
)。
integer 是集合 ℤ = {..., -2, -1, 0, 1, 2, ...} 中的某个数。
整型值可使用十进制,十六进制,八进制或二进制表示,前面能够加上可选的符号(- 或者 +)。
要使用八进制表达,数字前必须加上 0
(零)。要使用十六进制表达,数字前必须加上 0x
。要使用二进制表达,数字前必须加上 0b
。
<?php $a = 1234; // 十进制数 $a = -123; // 负数 $a = 0123; // 八进制数 (等于十进制 83) $a = 0x1A; // 十六进制数 (等于十进制 26) $a = 0b11111111; // 二进制数字 (等于十进制 255) ?>
整型数的字长和平台有关,尽管一般最大值是大约二十亿(32 位有符号)。64 位平台下的最大值一般是大约 9E18,除了 Windows 下 PHP 7 之前的版本,老是 32 位的。 PHP 不支持无符号的 integer。Integer 值的字长能够用常量 PHP_INT_SIZE
来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值能够用常量 PHP_INT_MAX
来表示,最小值能够在 PHP 7.0.0 及之后的版本中用常量 PHP_INT_MIN
表示。
若是给定的一个数超出了 integer
的范围,将会被解释为 float
。一样若是执行的运算结果超出了 integer
范围,也会返回 float
。
PHP 中没有整除的运算符。1/2 产生出 float 0.5。 值能够舍弃小数部分,强制转换为 integer
,或者使用 round()
函数能够更好地进行四舍五入。
要明确地将一个值转换为 integer
,用 (int)
或 (integer)
强制转换。不过大多数状况下都不须要强制转换,由于当运算符,函数或流程控制须要一个 integer
参数时,值会自动转换。还能够经过函数 intval()
来将一个值转换成整型。
思考下如下两种流程控制的区别:
<?php $num = '1'; if(1 == $num){ # code ... } if($num == 1){ # code ... } ?>
将 resource
转换成 integer
时, 结果会是 PHP 运行时为 resource
分配的惟一资源号。
当从浮点数转换成整数时,将向下取整。
若是浮点数超出了整数范围(32 位平台下一般为 +/- 2.15e+9 = 2^31
,64 位平台下,除了 Windows,一般为 +/- 9.22e+18 = 2^63
),则结果为未定义,由于没有足够的精度给出一个确切的整数结果。在此状况下没有警告,甚至没有任何通知!
PHP 7.0.0 起,NaN
和 Infinity
在转换成 integer
时,再也不是 undefined
或者依赖于平台,而是都会变成零。
毫不要将未知的分数强制转换为 integer,这样有时会致使不可预料的结果。
<?php echo (int) ( (0.1+0.7) * 10 ); // 显示 7! ?>
浮点型(也叫浮点数 float,双精度数 double 或实数 real)能够用如下任一语法定义:
<?php $a = 1.234; $b = 1.2e3; $c = 7E-10; ?>
浮点数的字长和平台相关,尽管一般最大值是 1.8e308 并具备 14 位十进制数字的精度(64 位 IEEE 格式)
浮点数的精度有限。尽管取决于系统,PHP 一般使用 IEEE 754 双精度格式,则因为取整而致使的最大相对偏差为 1.11e-16。非基本数学运算可能会给出更大偏差,而且要考虑到进行复合运算时的偏差传递。
此外,以十进制可以精确表示的有理数如 0.1 或 0.7,不管有多少尾数都不能被内部所使用的二进制精确表示,所以不能在不丢失一点点精度的状况下转换为二进制的格式。这就会形成混乱的结果:例如,floor((0.1+0.7)*10) 一般会返回 7 而不是预期中的 8,由于该结果内部的表示实际上是相似 7.9999999999999991118...。
因此永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。若是确实须要更高的精度,应该使用任意精度数学函数或者 gmp 函数。
如上述警告信息所言,因为内部表达方式的缘由,比较两个浮点数是否相等是有问题的。不过仍是有迂回的方法来比较浮点数值的。
要测试浮点数是否相等,要使用一个仅比该数值大一丁点的最小偏差值。该值也被称为机器极小值(epsilon)或最小单元取整数,是计算中所能接受的最小的差异值。
$a 和 $b 在小数点后五位精度内都是相等的。
<?php $a = 1.23456789; $b = 1.23456780; $epsilon = 0.00001; if(abs($a-$b) < $epsilon) { echo "true"; } ?>
某些数学运算会产生一个由常量 NAN
(not a number) 所表明的结果。此结果表明着一个在浮点数运算中未定义或不可表述的值。任何拿此值与其它任何值(除了 TRUE
)进行的松散或严格比较的结果都是 FALSE
。
因为 NAN
表明着任何不一样值,不该拿 NAN
去和其它值进行比较,包括其自身,应该用 is_nan()
来检查。
一个字符串 string
就是由一系列的字符组成,其中每一个字符等同于一个字节。这意味着 PHP 只能支持 256 的字符集,所以不支持 Unicode
。
分析一下:
1 Byte = 8 bit 因为1个字节存储一个字符,那么1字节所能存储字符的可能性为:2^8=256
一个字符串能够用 4 种方式表达:
定义一个字符串的最简单的方法是用单引号把它包围起来(字符 ')。
要表达一个单引号自身,需在它的前面加个反斜线()来转义。要表达一个反斜线自身,则用两个反斜线(\)。其它任何方式的反斜线都会被当成反斜线自己:也就是说若是想使用其它转义序列例如 r 或者 n,并不表明任何特殊含义,就单纯是这两个字符自己。
不像双引号和 heredoc 语法结构,在单引号字符串中的变量和特殊字符的转义序列将不会被替换。
果字符串是包围在双引号(")中, PHP 将对一些特殊的字符进行解析:
序列 | 含义 |
---|---|
n | 换行(ASCII 字符集中的 LF 或 0x0A (10)) |
r | 回车(ASCII 字符集中的 CR 或 0x0D (13)) |
t | 水平制表符(ASCII 字符集中的 HT 或 0x09 (9)) |
v | 垂直制表符(ASCII 字符集中的 VT 或 0x0B (11))(自 PHP 5.2.5 起) |
e | Escape(ASCII 字符集中的 ESC 或 0x1B (27))(自 PHP 5.4.0 起) |
f | 换页(ASCII 字符集中的 FF 或 0x0C (12))(自 PHP 5.2.5 起) |
\ | 反斜线 |
$ | 美圆标记 |
" | 双引号 |
[0-7]{1,3} | 符合该正则表达式序列的是一个以八进制方式来表达的字符 |
x[0-9A-Fa-f]{1,2} | 符合该正则表达式序列的是一个以十六进制方式来表达的字符 |
和单引号字符串同样,转义任何其它字符都会致使反斜线被显示出来。
用双引号定义的字符串最重要的特征是变量会被解析。
第三种表达字符串的方法是用 heredoc 句法结构:<<<
。在该运算符以后要提供一个标识符,而后换行。接下来是字符串 string
自己,最后要用前面定义的标识符做为结束标志。
结束时所引用的标识符必须在该行的第一列,并且,标识符的命名也要像其它标签同样遵照 PHP 的规则:只能包含字母、数字和下划线,而且必须以字母和下划线做为开头。
要注意的是结束标识符这行除了可能有一个分号(;)外,绝对不能包含其它字符。这意味着标识符不能缩进,分号的先后也不能有任何空白或制表符。更重要的是结束标识符的前面必须是个被本地操做系统承认的换行,好比在 UNIX 和 Mac OS X 系统中是 n,而结束定界符(可能其后有个分号)以后也必须紧跟一个换行。
若是不遵照该规则致使结束标识不“干净”,PHP 将认为它不是结束标识符而继续寻找。若是在文件结束前也没有找到一个正确的结束标识符,PHP 将会在最后一行产生一个解析错误。
Heredocs 结构不能用来初始化类的属性。自 PHP 5.3 起,此限制仅对 heredoc 包含变量时有效。
Heredoc 结构就象是没有使用双引号的双引号字符串,这就是说在 heredoc 结构中单引号不用被转义,可是上文中列出的转义序列还可使用。变量将被替换,但在 heredoc 结构中含有复杂的变量时要格外当心。
在 PHP 5.3.0 之后,也能够用 Heredoc 结构来初始化静态变量和类的属性和常量。
自 PHP 5.3.0 起还能够在 Heredoc 结构中用双引号来声明标识符:
<?php echo <<<"FOOBAR" Hello World! FOOBAR; ?>
就像 heredoc 结构相似于双引号字符串,Nowdoc 结构是相似于单引号字符串的。Nowdoc 结构很象 heredoc 结构,可是 nowdoc 中不进行解析操做。这种结构很适合用于嵌入 PHP 代码或其它大段文本而无需对其中的特殊字符进行转义。与 SGML 的 <![CDATA[ ]]> 结构是用来声明大段的不用解析的文本相似,nowdoc 结构也有相同的特征。
一个 nowdoc 结构也用和 heredocs 结构同样的标记 <<<
, 可是跟在后面的标识符要用单引号括起来,即 <<<'EOT'
。Heredoc 结构的全部规则也一样适用于 nowdoc 结构,尤为是结束标识符的规则。