登录
首页 >  文章 >  php教程

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

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

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

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

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

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

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

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

<?php
function countNestedArrays($array): int {
    $count = 0;

    foreach ($array as $item) {
        if (is_array($item)) {
            $count++; // 当前层级发现一个数组
            $count += countNestedArrays($item); // 递归统计其内部所有子数组
        }
    }

    return $count;
}

// 示例用法
$array = [10, 'hello', [1, 2, 3, ['hi', 7]], [15, 67], 12];
$result = countNestedArrays($array);
echo "Found $result arrays\n"; // 输出:Found 3 arrays
?>

关键优势说明:

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

⚠️ 注意事项:

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

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

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

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

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>