php中的函数内部函数:错误:无法重新声明

前端之家收集整理的这篇文章主要介绍了php中的函数内部函数:错误:无法重新声明前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有这个 PHP脚本:
function hoeveelzijner ($jaar,$id)
{
            function hoeveelhoeveel($beginstamp,$endstamp,$id)
            {
                $dates = MysqL_query('SELECT v_date FROM visitors WHERE id="'.$id.'" AND v_date<"'.$endstamp.'" AND v_date>"'.$beginstamp.'"');
                return MysqL_num_rows($dates);
            }
$i = 1;
while ($i < 13)
{
    $hoeveel[$i-1] = hoeveelhoeveel(mktime(0,$i,1,$jaar),mktime(0,cal_days_in_month(CAL_GREGORIAN,$id);
    $i = $i+1;
}
return $hoeveel;
}

当我把它放在它下面时,它工作得很好:

$values = hoeveelzijner(2005,1);

但是,当我这样做两次时,例如:

$values = hoeveelzijner(2005,1);
$test = hoeveelzijner(2000,4);

我收到此错误:致命错误:无法重新声明hoeveelhoeveel()(先前在…:69中声明)在第69行……

谁知道我做错了什么?如果我只能使用一次,它有点破坏了使用函数的目的……

额外信息:我不包含任何其他文件,也不会在脚本中的其他位置重新声明该功能.

非常感谢!

你不仅可以使用一次;你只能声明一次.每次使用函数hoeveelzijner时,都会声明函数hoeveelhoeveel.如果您多次调用它,您将重新声明它,这是禁止的.

您有两个选择:第一个是在包含函数之外的函数定义.该函数将在首次解析文件时声明,然后重复使用.如果要将函数定义限制在特定范围内(原则上是个好主意),可以使用PHP 5.3中引入的匿名函数语法:

function hoeveelzigner($jaar,$id)
{
    $hoeveelhoeveel = function($beginstamp,$id)
    {
            $dates = MysqL_query('SELECT v_date FROM visitors WHERE id="'.$id.'" AND v_date<"'.$endstamp.'" AND v_date>"'.$beginstamp.'"');
            return MysqL_num_rows($dates);
    };

    // etc
}

然后,您可以将此功能用作$hoeveelhoeveel(…).

猜你在找的PHP相关文章