PHP变量以$开头、弱类型、区分大小写;isset()检查存在且非null,empty()将0、"0"、false等判为“空”;作用域需global声明,引用赋值慎用,对象默认引用语义。

PHP变量不需要声明类型,但必须以$开头
PHP是弱类型语言,变量无需提前定义类型,只要用$加合法标识符就能创建。比如$name、$count、$is_valid都有效,但name(没$)或$123abc(数字开头)会报错。
常见错误现象:直接写name = "test",结果是语法错误——PHP不会把它当变量,而是当成常量查找,最终触发Notice: Use of undefined constant name。
- 变量名区分大小写:
$Name和$name是两个不同变量 - 不能用关键字做变量名,如
$echo、$class虽不报错,但可读性差且易混淆 - 推荐用下划线分隔(
$user_id)而非驼峰($userId),因PHP原生函数和PSR规范普遍采用前者
isset()和empty()判断变量前必须先理解它们的差异
很多新手以为empty($var)只是“检查是否为空”,其实它会把0、"0"、false、null、[]都判为真(即“空”),而isset($var)只关心变量是否存在且不为null。
典型使用场景:表单接收$_POST['age'],用户输入0是合法值,但empty($_POST['age'])会误判为“未填写”。这时该用isset($_POST['age']) && $_POST['age'] !== ''更稳妥。
立即学习“PHP免费学习笔记(深入)”;
-
isset()支持多个参数,isset($a, $b, $c)等价于isset($a) && isset($b) && isset($c) -
empty()不是函数而是语言结构,括号可省略,但建议保留以提高可读性 - 从PHP 7.4起,
??空合并运算符更简洁:$value = $_GET['id'] ?? 'default';
变量作用域决定它在哪儿能被访问,全局变量需显式声明
函数内部无法直接读写外部变量,除非用global关键字或$GLOBALS超全局数组。不声明就直接赋值,只会创建一个局部变量。
例如:
$counter = 0;
function inc() {
$counter++; // 这里操作的是局部变量,$counter仍是0
}
inc();
echo $counter; // 输出0
正确做法是:
function inc() {
global $counter;
$counter++;
}
-
global只是把外部变量引入当前作用域,不是引用传递;修改它会影响原变量 - 静态变量
static $cache在函数多次调用间保持值,适合缓存计算结果 - 闭包中用
use ($var)捕获外部变量,注意默认是值传递,要引用得写use (&$var)
引用赋值&容易引发意外修改,慎用于数组和对象
PHP默认按值复制变量,但$b = &$a会让两者指向同一内存地址。改$b等于改$a。对简单类型影响小,但对大数组或对象时,可能破坏预期逻辑。
比如循环中误用引用:
$items = ['a', 'b', 'c'];
foreach ($items as &$item) {
$item = strtoupper($item);
}
// $items变成['A','B','C'] —— 这是预期效果
// 但紧接着再跑一次foreach(没加&),$item仍引用最后一个元素,导致污染
- 循环结束后记得
unset($item),避免后续代码意外修改数组末尾 - 对象在PHP 5+默认就是引用语义(实际是“对象标识符”复制),
$obj2 = $obj1已足够共享状态,无需& - 用
clone $obj深拷贝对象,否则$obj2 = $obj1后改属性,$obj1也会变
isset/empty的隐式转换、作用域边界、引用与对象语义的混用,是线上bug最常藏身的地方。写的时候多想一步“这个变量此刻到底存不存在?它的值有没有被意外覆盖?”。










