首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >检查数组是否为多维?

检查数组是否为多维?
EN

Stack Overflow用户
提问于 2008-09-28 06:23:13
回答 25查看 109.2K关注 0票数 154

检查一个数组是否是由原始值组成的平面数组的最有效方法是还是多维array

  • Is有什么方法可以做到这一点,而不是实际循环一个数组并对它的每个元素运行
EN

回答 25

Stack Overflow用户

回答已采纳

发布于 2008-09-28 06:29:31

简短的回答是,如果‘第二维’可以在任何地方,你不能在没有隐式循环的情况下做到这一点。如果一定要放在第一个项目中,你可以这样做

代码语言:javascript
复制
is_array($arr[0]);

但是,我能找到的最有效的通用方法是在数组上使用foreach循环,只要找到命中就缩短路径(至少隐式循环比直接的for()更好):

代码语言:javascript
复制
$ more multi.php
<?php

$a = array(1 => 'a',2 => 'b',3 => array(1,2,3));
$b = array(1 => 'a',2 => 'b');
$c = array(1 => 'a',2 => 'b','foo' => array(1,array(2)));

function is_multi($a) {
    $rv = array_filter($a,'is_array');
    if(count($rv)>0) return true;
    return false;
}

function is_multi2($a) {
    foreach ($a as $v) {
        if (is_array($v)) return true;
    }
    return false;
}

function is_multi3($a) {
    $c = count($a);
    for ($i=0;$i<$c;$i++) {
        if (is_array($a[$i])) return true;
    }
    return false;
}
$iters = 500000;
$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi($a);
    is_multi($b);
    is_multi($c);
}
$end = microtime(true);
echo "is_multi  took ".($end-$time)." seconds in $iters times\n";

$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi2($a);
    is_multi2($b);
    is_multi2($c);
}
$end = microtime(true);
echo "is_multi2 took ".($end-$time)." seconds in $iters times\n";
$time = microtime(true);
for ($i = 0; $i < $iters; $i++) {
    is_multi3($a);
    is_multi3($b);
    is_multi3($c);
}
$end = microtime(true);
echo "is_multi3 took ".($end-$time)." seconds in $iters times\n";
?>

$ php multi.php
is_multi  took 7.53565130424 seconds in 500000 times
is_multi2 took 4.56964588165 seconds in 500000 times
is_multi3 took 9.01706600189 seconds in 500000 times

隐式循环,但我们不能一找到匹配就走捷径...

代码语言:javascript
复制
$ more multi.php
<?php

$a = array(1 => 'a',2 => 'b',3 => array(1,2,3));
$b = array(1 => 'a',2 => 'b');

function is_multi($a) {
    $rv = array_filter($a,'is_array');
    if(count($rv)>0) return true;
    return false;
}

var_dump(is_multi($a));
var_dump(is_multi($b));
?>

$ php multi.php
bool(true)
bool(false)
票数 144
EN

Stack Overflow用户

发布于 2009-06-15 05:33:46

使用count()两次;一次在默认模式下,一次在递归模式下。如果值匹配,则数组不是多维数组,因为多维数组具有更高的递归计数。

代码语言:javascript
复制
if (count($array) == count($array, COUNT_RECURSIVE)) 
{
  echo 'array is not multidimensional';
}
else
{
  echo 'array is multidimensional';
}

这个选项的第二个值mode是在PHP4.2.0中添加的。从PHP Docs

如果可选模式参数设置为COUNT_RECURSIVE (或1),count()将递归计数数组。这对于计算多维数组的所有元素特别有用。count()不检测无限递归。

但是,此方法不能检测array(array())

票数 222
EN

Stack Overflow用户

发布于 2008-09-29 21:02:19

对于PHP 4.2.0或更高版本:

代码语言:javascript
复制
function is_multi($array) {
    return (count($array) != count($array, 1));
}
票数 30
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/145337

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档