5.1.11.1. 低精度
php中并不是用高精度来存储浮点数,而是用使用 IEEE 754 双精度格式,造成在涉及到浮点数比较的时候可能会出现预期之外的错误。
比如 php -r "var_dump(0.2+0.7==0.9);"
这行代码的输出是 bool(false)
而不是 bool(true)
。这在一些情况下可能出现问题。
5.1.11.2. 弱类型
如果使用 ==
来判断相等,则会因为类型推断出现一些预料之外的行为,比如magic hash,指当两个md5值都是 0e[0-9]{30}
的时候,就会认为两个hash值相等。
另外在判断字符串和数字的时候,PHP会自动做类型转换,那么 1=="1a.php"
的结果会是true
另外在判断一些hash时,如果传入的是数组,返回值会为 NULL
, 因此在判断来自网络请求的数据的哈希值时需要先判断数据类型。
同样的, strcmp()
ereg()
strpos()
这些函数在处理数组的时候也会异常,返回NULL。