PHP 7引入参数和返回值类型声明,支持int、float、string、bool、array等类型,通过declare(strict_types=1)启用严格模式可禁用隐式转换;PHP 7.1起支持?nullable类型和void返回类型,提升代码健壮性与可读性。

PHP 7 开始引入了函数参数和返回值的类型声明功能,使得开发者可以更严格地约束函数的输入与输出类型,提升代码的可读性和健壮性。这一特性在 PHP 7.0 及更高版本中逐步完善,特别是在 PHP 7.1 和 7.4 中增加了更多支持。
参数类型声明
在 PHP 7+ 中,可以在函数参数前指定类型,强制传入的值必须符合该类型,否则会抛出 TypeError 异常。
支持的参数类型包括:- 标量类型:int、float、string、bool
- 复合类型:array、callable、self、parent(类中使用)
- 类与接口名:自动进行实例类型检查
示例:
function add(int $a, float $b): float {
return $a + $b;
}
add(1, 2.5); // 正确
add("1", "2.5"); // 自动转换(若开启严格模式则报错)
注意:默认情况下 PHP 会尝试进行类型转换。要禁用此类转换,需启用严格模式:
立即学习“PHP免费学习笔记(深入)”;
declare(strict_types=1);
此声明必须放在文件顶部,仅对当前文件生效。
返回值类型声明
使用冒号后接类型来声明函数返回值的类型,确保函数返回预期的数据类型。
语法格式:
function func(...): returnType
示例:
function getItems(): array {
return ['apple', 'banana'];
}
function getAge(): int {
return 25;
}
从 PHP 7.1 开始支持 nullable 类型,通过在类型前加问号 ? 表示返回值可以为 null:
function findUser(): ?string {
if ($notFound) {
return null;
}
return "John";
}
常见用法与注意事项
结合类与对象使用时,类型声明非常有用:
class User {}
function processUser(User $user): void {
echo "Processing user...";
}
void 返回类型(PHP 7.1+)表示函数不返回任何值,返回 null 也不允许显式 return 值。
几点提醒:
- 启用 strict_types=1 可避免隐式类型转换带来的问题
- 类型声明不支持资源或 null 作为参数类型(但可用 ?type 表示可为空)
- 闭包同样支持类型声明
基本上就这些。合理使用类型声明能让 PHP 更接近强类型语言的开发体验,减少运行时错误。只要注意版本兼容性和严格模式设置,就能有效提升项目质量。











