PHP 8.5 新特性 闭包可以作为常量表达式了

news/2025/10/21 7:38:13/文章来源:https://www.cnblogs.com/catchadmin/p/19154035

PHP 8.5 新特性 闭包可以作为常量表达式了

PHP 8.5 又带来了一个让人兴奋的新特性:闭包现在可以作为常量表达式使用了,这意味着它们可以出现在默认参数或属性值中。

你是不是也遇到过这种情况:想在 PHP 中把闭包设置为默认参数值,结果只能想各种变通方案?在 PHP 8.5 中,这个烦恼终于没了。闭包现在可以作为常量表达式——也就是说,它们可以用在任何你之前只能用字面值的地方。

我之前就被这个限制坑过,而且不止一次。现在,你可以在这些地方使用闭包了:

  • 默认参数值
  • 常量值
  • 属性默认值
  • 属性参数值
  • 还有更多

PHP 8.5 新特性 闭包可以作为常量表达式了

默认值

以前,我会写这样的代码:

function someFunction(mixed $someValue, ?callable $callback = null): bool
{$callback ??= fn () => true;return $callback($someValue);
}

或者这样:

final class SomeClass
{private Closure $someCallable;public function __construct(){$this->someCallable = function (mixed $value): bool {// 待实现return true;};}
}

有了闭包常量表达式,这两个例子都可以简化成:

function someFunction(mixed $someValue,callable $callback = static function () { return true; },
): bool {return $callback($someValue);
}final class SomeClass
{private Closure $someCallable = static function (mixed $value): bool {// 待实现return true;};
}

不用再写 $callback ??= 这种绕来绕去的代码了。直接把闭包作为默认参数值是我经常要做的事,现在能够通过避免像 null 这种无意义的值来精简公共接口,这个改进真的很棒。

属性(Attributes)

这是另一个很赞的改变——你现在可以直接在属性中定义函数了。比如:

#[Attribute(Attribute::TARGET_PROPERTY)]
final readonly class TruthyValidator
{public function __construct(public Closure $truthyValidator = static function(mixed $value): bool {return (bool) $value;}) {}
}

这是一个简单的验证器属性,用来检查值是否为真值,默认实现就是把它转成布尔值,让 PHP 自己处理转换。但假如你想把字符串 '0' 也当作真值:

#[TruthyValidator(truthyValidator: static function(string|int|null $value): bool {return $value === '0' || $value;
})]
public string|int|null $someProperty = null;

First-Class Callables

严格来说这是一个独立的 RFC,但它是因为投票原因才拆分的,技术上并不是独立的,所以我在同一篇文章里一起介绍。

除了标准的闭包(你可以内联定义函数体),现在你也可以用 first-class callables 作为常量表达式了。这意味着上面所有的例子也都适用于它们。

<?php// 定义一个默认验证器
function defaultValidatorFunction(mixed $value): bool
{return (bool) $value;
}// 定义验证器类
#[Attribute(Attribute::TARGET_PROPERTY)]
final readonly class TruthyValidator
{public function __construct(// 使用 first-class callable 语法分配默认验证器public Closure $truthyValidator = defaultValidatorFunction(...),) {}
}// 定义我们自定义的验证函数
function truthyValidatorWithoutZeroString(string|int|null $value): bool
{return $value === '0' || $value;
}class SomeClassToBeValidated
{// 用 first-class callable 的方式使用它#[TruthyValidator(truthyValidator: truthyValidatorWithoutZeroString(...))]public string|int|null $someProperty = null;
}

总结

我个人真的很喜欢这个新特性,因为它——就像最近的很多其他改进一样——让 PHP 变成了一门更简洁、更一致的语言,减少了各种 hack 和怪异的语法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/941894.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JavaScript-基础】split,splice,slice 三者的用法

split,splice,slice 三者的用法 很多知识点不熟悉可以自行去下面链接查询: mdn web docs 最近一直忙于搞python,等后续有时间更新python相关的内容。毕竟现在在弄web.有些知识点需要巩固,以便自己后续带人和巩固自己…

2025 代码源 CSP-S 模拟赛复盘

Day 16 T1 双重心 分类讨论一下:是原树的双重心之一,考虑把这条边割掉,接到另一个连通块的任意一个点上都是可行的。 不割掉原树上的双重心的边,两侧的连通块内的的任意一条边可以断开,连通块内相互连边就行。 考…

2025.10.21——1绿

普及+/提高 P1347 排序 wpmx昨晚写的有意思的题,数据范围比较小,我就直接用set+m次拓扑排序,30min写出来,要注意输出顺序后的句号,以及特判n==1

【JavaScript-基础】map、forEach、for、for in、for of等的区别

tips:循环虽好,大家都得按自己所需场景进行使用。个人建议,不喜勿喷 forEach forEach: forEach(item,index,array), item:当前处理的数据,index:下标, array:整个数组 遍历全部数据,不能通过return结束循环,消耗…

dotnet 利用 Windows 注册表实现开机自动启动

本文记录一个开机自动启动实现方法,通过写入到注册表实现开机之后,用户登录完成之后让应用程序开机自启本文将演示写入 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run 注册表路线,实现应用程序…

帮我回答这些问题

◦ 以太坊交易的数据结构及EIP1559/712协议的理解。 ◦ 以太坊的账⼾是如何⽣产的,公私钥的关系。 ◦ 以太坊区块链浏览器⼀般会展⽰哪些信息,⼤概能知道。 ◦ 以太坊交易nonce的作⽤,nonce异常交易如何处理。 ◦ 以…

使用uWSGI和Nginx部署深度学习模型指南

本文详细介绍了如何通过uWSGI应用服务器和Nginx反向代理将深度学习模型部署为可扩展的Web服务,涵盖WSGI协议原理、服务器配置步骤及性能优化要点,帮助构建高并发生产级AI应用。如何使用uWSGI和Nginx部署深度学习模型…

Python 类属性的应用场景

Python 类属性的应用场景 在面向对象编程中,类属性作为一种特殊的属性形式,始终扮演着“共享者”与“管理者”的角色。与实例属性为每个对象单独存储数据不同,类属性属于类本身,被所有实例共同拥有和访问。这种特性…

快速提升Entra ID安全性的实用指南

本文详细介绍了如何通过配置用户默认设置、保护特权角色、管理条件访问策略等关键步骤,快速提升Microsoft Entra ID的安全性,帮助企业构建更强大的云身份防护体系。快速提升Entra ID安全性 在2025年10月的BSides北弗…

为什么很多人分不清关联和聚合?

为什么很多人分不清关联和聚合 这个问题确实很常见,很多人(包括有经验的开发者)都会混淆关联和聚合。让我从多个角度分析这个现象的原因。 主要混淆原因 1. 代码实现的高度相似性 # 关联关系的代码 class Universit…

机器学习商业应用实战指南

本文详细介绍了在企业中应用机器学习的完整流程,从问题识别到团队建设、基础设施搭建、数据策略制定,再到MVP开发和持续迭代,为企业实施AI转型提供了系统性的技术指导。将机器学习应用于您的业务 在这篇文章中,我将…

在线签名工具,手写签名保存为png图片,用于生成电子签名用于word文档等

原文链接:https://blog.nanzhi.vip/?article_id=30&type=software 应用案例: 每天进步一点点

什么情况下,有必要将属性设为类属性而非实例属性?

类属性(Class Attribute)是定义在类中、不属于任何实例的属性,它被该类的所有实例共享。将属性设为类属性而非实例属性的必要性,主要体现在数据共享、全局状态维护、节省内存等场景中。以下从核心作用和具体示例两…

在线签名工具,保存为png图片,用于生成电子签名用于word文档等

原文链接:https://blog.nanzhi.vip/?article_id=30&type=software 应用案例: 每天进步一点点

玄机——第五章 Windows 实战-evtx 文件分析

第五章 Windows 实战-evtx 文件分析 切勿在本地运行 1.将黑客成功登录系统所使用的IP地址作为Flag值提交; 拿到文件后传入虚拟机打开 第一个是安全日志,在日志中过滤编号为4625(登录失败),4624(登录成功)的事件 从下…

251021

251021一觉醒来,我又活在了那份恐慌里,脚下飘飘,身体却很沉,这是清醒的代价,天堂和地狱都在人间

CityRefer:城市规模点云数据上的地理感知 3D 视觉接地数据集 - MKT

CityRefer:城市规模点云数据上的地理感知 3D 视觉接地数据集 城市规模的 3D 点云是表达精细复杂户外结构的一种有效方式。它涵盖了城市各个组成部分(包括汽车、街道和建筑物)的外观和几何特征,可用于实现自动驾驶汽…

SensatUrban语义分割数据集SensatUrban - MKT

SensatUrban语义分割数据集SensatUrban https://github.com/QingyongHu/SensatUrban 地面:包括不透水表面、草地、地形 植被:包括乔木、灌木、树篱、灌木丛 建筑:包括商业/住宅建筑 墙体:包括栅栏、高速公路护栏…

推荐算法参考资料

协同过滤 https://cloud.tencent.com/developer/article/1085760 Wide & Deep https://blog.csdn.net/qq_42363032/article/details/115935964 DIN https://blog.csdn.net/u012328159/article/details/123043033 指…

LLM学习笔记DAY8

📘今日学习总结 大语言模型提示技术学习笔记 1 提示工程 1.1 提示设计关键要素 五大核心要素:任务描述:清晰明确的任务指令,包含目标、限制条件、数据格式等 上下文信息:提供背景知识,帮助模型突破知识局限 输入…