PHP数据类型分标量、复合、特殊三类,类型动态附着于值且随上下文变化;int/float自动切换有精度风险;array是有序哈希表;null、unset、empty语义不同;resource/object需手动释放。

PHP 的数据类型不是固定不变的“八种清单”,而是分两类:标量 + 复合 + 特殊,且 gettype() 返回的字符串和实际底层行为常有偏差——别背分类,要盯住变量在具体操作中怎么表现。
标量类型里,int 和 float 的边界在哪
PHP 会自动在整数和浮点数间切换,但切换不是无代价的:
- 32 位系统上,超过
2147483647的整数会被悄悄转成float,精度开始丢失(比如9223372036854775807变成9.2233720368548E+18) -
is_int()判定的是当前类型,不是“它本来是不是整数”;(int)3.9是int,但3.0 + 0.0是float - 用
filter_var($x, FILTER_VALIDATE_INT)比is_int()更可靠,尤其处理表单输入时
array 不是“容器”,是有序映射表
PHP 的 array 本质是哈希表实现的有序字典,这直接决定它的行为:
-
count()是 O(1),但array_keys()或array_values()是 O(n),别在循环里反复调用 - 数字键不连续时,
foreach仍按插入顺序遍历,不是按数值大小;array_merge([1=>'a'], [0=>'b'])结果是[1=>'a', 0=>'b'],不是重排 - 用
[]创建空数组比array()略快(PHP 7+ 差异极小,但旧代码里常见array()导致意外的引用传递)
null、unset 和 empty 完全不是一回事
这三个常被混用,但语义和副作用截然不同:
立即学习“PHP免费学习笔记(深入)”;
-
$x = null:变量存在,值为null;isset($x)返回false -
unset($x):变量被销毁;再次访问会触发Notice: Undefined variable -
empty($x)对0、"0"、[]、false都返回true,但0.0和"0.0"不是空——别拿它校验数字输入 - 判断变量是否“真有值”,优先用
isset($x) && $x !== '',而不是!empty($x)
resource 和 object 的生命周期容易被忽略
这两类类型不参与常规变量赋值逻辑,出错往往在释放时机:
-
fopen()返回的resource必须显式fclose();PHP 脚本结束时虽会自动清理,但大文件或高并发下可能提前耗尽系统文件描述符 -
mysqli或PDO对象里的连接资源,不是 unset 对象就能断开;要用$pdo = null或显式$pdo->close() -
__destruct()不保证执行时机,不能依赖它做关键清理;数据库事务、锁、临时文件必须手动控制
类型判断最危险的误区,是以为 gettype() 返回什么,变量就“属于”那个类型——PHP 的类型是动态附着在值上的,而值可能随时被函数、运算或隐式转换改写。盯住上下文,而不是分类表。











