这期内容当中小编将会给大家带来有关PHP中匿名函数的作用是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
◆字符串的函数名
◆使用create_function的返回
51CTO推荐专题:PHP开发基础入门
在PHP5.3以后, 我们多了一个选择, 也就是Closure。
$func = function () { ... }; array_walk($arr, $func);
从实现上来说, ***种方式: 传递函数名字符串是最简单的。而第二种方式create_function, 其实和***种方式本质上一样的, create_function返回一个字符串的函数名, 这个函数名的格式是:
"\000_lambda_" . count(anonymous_functions)++
我们来看看create_function的实现步骤:
获取参数, 函数体;
拼凑一个"function __lambda_func (参数) { 函数体;} "的字符串;
eval;
通过__lambda_func在函数表中找到eval后得到的函数体, 找不到就出错;
定义一个函数名:"\000_lambda_" . count(anonymous_functions)++;
用新的函数名替换__lambda_func;
返回新的函数。
我们来验证下:
<?php create_function("", 'echo __FUNCTION__;'); call_user_func("\000lambda_1", 1); ?> //输出 __lambda_fun
因为在eval的时候, 函数名是”__lambda_func”, 所以匿名函数内会输出__lambda_func, 而因为***用”\000_lambda_”.count(anonymous_functions)++重命名了函数表中的”__lambda_func”函数, 所以可通过”\000_lambda_” . count(anonymous_functions)++调用这个匿名函数。为了证实这一点, 可以将create_function的返回值dump出来查看。
而在PHP 5.3发布的时候, 其中有一条new feature就是支持闭包/Lambda Function, 我***反应是以为zval新增了一个IS_FUNCTION, 但实际上是构造了一个PHP 5.3引入的Closure”类”的实例, Closure类的构造函数是私有的, 所以不能被直接实例化, 另外Closure类是Final类, 所以也不能做为基类派生子类.
//php-5.3.0 $class = new ReflectionClass("Closure"); var_dump($class->isInternal()); var_dump($class->isAbstract() ); var_dump($class->isFinal()); var_dump($class->isInterface()); //输出: bool(true) bool(false) bool(true) bool(false) ?>
而PHP 5.3中对闭包的支持, 也仅仅是把要保持的外部变量, 做为Closure对象的”Static属性”(并不是普通意义上的可遍历/访问的属性).
//php-5.3.0 $b = "laruence"; $func = function($a) use($b) {}; var_dump($func);
上述就是小编为大家分享的PHP中匿名函数的作用是什么了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。