0

0

函数怎么返回值_PHP函数返回值写法【教程】

蓮花仙者

蓮花仙者

发布时间:2026-03-12 22:05:33

|

319人浏览过

|

来源于php中文网

原创

PHP函数默认返回null,必须显式return;PHP7.1+支持[$a,$b]=func()解构数组,list()仅适用于数字键;PHP8.0+的void表示禁止return表达式而非禁止return语句;返回引用需谨慎,仅适用于长期存在的变量。

函数怎么返回值_php函数返回值写法【教程】

PHP 函数没返回值?return 忘写了或写在了错误位置

PHP 函数默认返回 null,不写 return 就等于什么都没给调用方。常见现象是:函数里明明做了计算、拼了字符串,但调用后变量是 null 或空——八成是漏了 return,或者它被卡在某个 if 分支里,路径没走通。

  • return 必须显式写出,PHP 不会自动返回最后一行表达式的值(不像 Ruby 或 JS 的箭头函数)
  • 检查所有分支路径,尤其是 if/elseswitch,确保每条可能执行的路径都有 return,或至少有一个兜底 return
  • 提前 return 是合法且常用的做法,比如参数校验失败直接 return false;,不用套一层 else

返回多个值只能靠数组或对象?list() 和 PHP 7.1+ 的结构化解包

PHP 原生不支持多值返回(如 Python 的 return a, b),但可以用数组“假装”返回多个值。关键是调用方怎么接——老写法容易出错,新语法更安全。

  • PHP 7.1+ 推荐用 [$a, $b] = myFunction();,前提是函数返回索引数组且长度匹配,否则报 Warning: Undefined array key
  • PHP 5.4–7.0 可用 list($a, $b) = myFunction();,但若函数返回 false 或非数组,会触发 Notice: Array to string conversion 或静默失败
  • 别依赖返回关联数组后用 list() 解构——list() 只认数字键,['name' => 'x', 'age' => 25] 这种会丢数据

函数返回 void?PHP 8.0+ 的类型声明不是摆设

PHP 8.0 加了 void 返回类型,但它只表示“不许有 return 表达式”,不是“不许写 return”。很多人配错类型后运行时报错,其实只是语法理解偏差。

  • 声明 function foo(): void { return; } 合法;但 function foo(): void { return 123; } 直接 Fatal error
  • 如果函数本意是“纯副作用”(比如写日志、发请求、改全局变量),用 void 能让 IDE 和静态分析工具提前拦住误用,比如有人写了 $x = foo();
  • 已有函数返回 null 却声明 void,升级到 PHP 8 后会报错;反过来,声明了 void 却实际返回值,也会被拒绝

返回引用要加 &,但多数时候你并不需要

function &myFunc() { return $var; } 确实能返回变量引用,但除非真要修改原变量,否则极易引发意外行为——比如返回局部变量的引用,PHP 会静默转成拷贝,你以为改了,其实没动。

立即学习PHP免费学习笔记(深入)”;

  • 返回引用只适用于:操作一个长期存在的变量(如类属性、全局数组元素),且明确需要后续修改影响源头
  • 返回函数内定义的普通变量(如 $tmp = 'abc'; return $tmp;)加 & 没意义,PHP 会警告 Only variable references should be returned by reference
  • 返回数组元素引用(如 &$arr[0])可行,但要注意数组本身是否可变;返回 new StdClass() 这类临时对象的引用,结果不可靠

最常被忽略的是:函数返回值类型和调用方的预期是否对齐。比如函数声明返回 string,但逻辑里某条路径漏了 return,实际返回 null,而调用方直接拿去 strlen() ——这时报错不在函数里,而在下游,排查起来绕一圈。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1030

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

569

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

441

2024.03.13

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

492

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

382

2023.10.25

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号