登录
推荐 文章 Go 技术 课程 下载 专题 AI
首页 >  文章 >  php教程

如何统计嵌套数组中所有子数组的数量

时间:2026-05-05 23:33:59 435浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《如何统计嵌套数组中所有子数组的数量 》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

如何统计嵌套数组中所有子数组的数量

本文介绍一种使用递归函数精确统计 PHP 数组中所有嵌套子数组(包括多层嵌套)数量的方法,适用于任意深度的混合类型数组,代码简洁可靠,可直接用于生产环境。

本文介绍一种使用递归函数精确统计 PHP 数组中所有嵌套子数组(包括多层嵌套)数量的方法,适用于任意深度的混合类型数组,代码简洁可靠,可直接用于生产环境。

在 PHP 中,若需统计一个数组中所有层级内出现的子数组总数(而非仅顶层元素中的数组),不能简单使用 array_filter($arr, 'is_array') 配合 count() —— 因为这只能统计第一层的数组元素,会忽略深层嵌套(如 $arr[2][3] 中的 ['hi', 7])。正确解法是采用递归遍历:对每个元素判断是否为数组;若是,则计数器加 1,并继续递归检查该子数组内部。

以下是一个健壮、易理解的实现:

关键优势说明:

  • 无全局变量:避免使用 global,函数纯正、可复用、线程安全;
  • 返回值设计:通过累加递归结果,自然支持任意嵌套深度;
  • 类型安全:is_array() 准确识别数组类型,不误判对象或资源;
  • 零副作用:不修改原数组,符合函数式编程原则。

⚠️ 注意事项:

  • 若数组存在循环引用(如 $arr[0] = &$arr),上述递归将导致无限调用和栈溢出。生产环境中如需处理不可信数据,建议结合 spl_object_hash() 或引用跟踪机制做防环检测;
  • 对超大深度嵌套(>100 层),PHP 默认 xdebug.max_nesting_level 可能触发错误,必要时可临时调整(但应优先优化数据结构)。

? 扩展建议:
如需同时获取各数组的路径(如 "[2][3]"),可在递归中传入当前路径字符串;若需区分“顶层数组”与“嵌套数组”,可增加 $depth 参数并按需过滤。

该方法简洁、高效、符合 PSR-12 编码规范,是处理嵌套数组计数问题的标准实践。

终于介绍完啦!小伙伴们,这篇关于《如何统计嵌套数组中所有子数组的数量 》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>