isset看变量是否存在且非null,empty看值在语义上是否为空(含0、"0"、false、""、[]等);isset对未定义变量安全,empty不报warning但不可用于表达式。

面试时被问到 isset 和 empty 的区别,核心就一句话:isset 看“有没有”,empty 看“算不算空”。前者管变量是否存在且非 null,后者管值在语义上是否为“空”——而这个“空”的范围很广,0、"0"、false、""、[] 全都算。
判断逻辑完全不同
isset($var) 返回 true 当且仅当:
– 变量已定义(不是未声明)
– 且值不为 null
empty($var) 返回 true 当:
– 变量未定义
– 或变量存在但值属于以下任一:null、false、0(整型/浮点)、"0"(字符串)、""(空字符串)、[](空数组)、未初始化对象
注意:empty 对未定义变量不报 warning;isset 对未定义变量也安全,但对表达式(如 empty($a + $b))会报错——它只接受变量。
立即学习“PHP免费学习笔记(深入)”;
典型陷阱场景
这些是面试官最爱挖坑的地方:
-
$age = 0;→isset($age)是true,empty($age)也是true。新生儿年龄为 0 是合法业务值,不能用empty判“用户没填” -
$_GET['id'] = '0';→!empty($_GET['id'])为false,直接跳过逻辑,但其实参数明确传了 -
$str = " ";(含空格)→isset($str)为true,empty($str)为false(因非空字符串),但trim($str) === ""才真该判为空 -
$arr = ['name' => ''];→empty($arr['name'])为true,但你无法区分是$arr['name']不存在,还是存在却等于空字符串
什么时候该用哪个?
验证字段是否提交(存在性)→ 用 isset
比如检查表单有没有传 email 字段:if (isset($_POST['email'])) { ... }
验证值是否有效(非空有意义)→ 少用 empty,优先用显式判断
比如确认邮箱非空且格式合理:if (isset($_POST['email']) && trim($_POST['email']) !== '' && filter_var($_POST['email'], FILTER_VALIDATE_EMAIL))
想同时判存在+非空字符串 → 推荐组合写法if (isset($val) && $val !== '') 比 !empty($val) 更可控
PHP 7.4+ 还可配合空合并:$val = $_POST['field'] ?? '';,再单独校验内容
和 is_null 的关系
is_null($var) 只在值严格等于 null 时返回 true,未定义变量也会触发 notice(除非 error_reporting 关闭)。isset($var) === !is_null($var) 在变量已定义前提下成立,但 isset 更安全——它天然兼容未定义情况。
简单记:is_null 是“是不是真空”,isset 是“有没有瓶子且瓶里有东西”,empty 是“瓶子看着像不像空的”。











