php 7 版本为函数返回值引入了标量类型声明的支持。借助这一功能,开发者可以明确指定函数应返回的数据类型。支持的返回类型包括:
- int
- float
- bool
- string
- 接口(interfaces)
- array
- callable
函数定义格式如下所示:
function myfunction(type $par1, type $param2): type {
// 函数体
return $val;
}在默认情况下,PHP 解析器使用的是弱类型检查机制。如果希望启用更严格的类型验证,则需要在脚本顶部添加 declare(strict_types=1)。
示例
下面这个例子中我们创建了一个名为 division() 的函数,并将它的返回类型设定为 int:
由于没有开启严格模式(即未设置 strict_types=1),即使传入的参数并非整型,程序依然可以正常运行并输出以下结果:
立即学习“PHP免费学习笔记(深入)”;
第一个数字: 20.5 第二个数字: 10 除法结果: 2
但如果你在文件开头加上 declare(strict_types=1);,则会触发一个致命错误:
随缘网络PHP企业网站管理系统V2.0正式发布,该企业网站管理系统采用PHP+MYSQL编写,界面色调风格延续之前1.0版管理系统简洁浅蓝色风格,稍有所变动。变更分类树形目录方式采用jquery库,产品,文章三级无限分类。希望大家能够喜欢。系统中难免有些小问题,希望大家在使用中有什么问题可到本站论坛提出,我们将总结各问题后给予修正并升级。本站再次声明对于免费版系列系统本站不提供QQ电话等技术咨询服
Fatal error: Uncaught TypeError: division(): Argument #1 ($x) must be of type int, float given, called in div.php on line 12 and defined in div.php:3
Stack trace:
#0 div.php(12): division(20.5, 10)
#1 {main}
thrown in div.php on line 3而且,在你编写代码时,VS Code 等编辑器就已经能显示出相关错误提示:

再看另一个示例
如果你想让 division() 函数返回 float 类型而非 int,可以尝试将分子强制转换为浮点数,然后观察 PHP 是否抛出错误:
取消顶部 declare 行的注释后运行代码,你会看到类似如下的致命错误信息:
第一个数字: 20
第二个数字: 10
PHP Fatal error: Uncaught TypeError: division(): Return value must be of type int, float returned in /home/cg/root/14246/main.php:5
Stack trace:
#0 /home/cg/root/14246/main.php(13): division()
#1 {main}
thrown in /home/cg/root/14246/main.php on line 5










