|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
建议大家买一本书,而不光是在网上看一些零碎的资料,一本书毕竟会讲的系统一些,全面一些,而且印刷的书不受电脑的限制,但是建议在看书的时候最好旁边有电脑,这样可以很及时地上机实践。
PHP中, 传递Callback的体例, 一向很丑恶. 在PHP5.3之前, 咱们只要俩种选择:
1. 字符串的函数名
2. 利用create_function的前往值
在PHP5.3今后, 咱们多了一个选择, 也就是Closure,
$func = function () { ... };
array_walk($arr, $func);
从完成下去说, 第一种体例: 传递函数名字符串是最复杂的.
而第二种体例create_function, 其实和第一种体例实质上一样的, create_function前往一个字符串的函数名, 这个函数名的格局是:
"\000_lambda_" . count(anonymous_functions)++;
咱们来看看create_function的完成步调:
1. 获得参数, 函数体
2. 拼集一个"function __lambda_func (参数) { 函数体;} "的字符串
3. eval之
4. 经由过程__lambda_func在函数表中找到eval后失掉的函数体, 找不到就失足
5. 界说一个函数名:"\000_lambda_" . count(anonymous_functions)++
6. 用新的函数名交换__lambda_func
7. 前往新的函数名
咱们来验证下:
<?php
create_function("", 'echo __FUNCTION__;');
call_user_func("\000lambda_1", 1);
?>
//输入
__lambda_func
由于在eval的时分, 函数名是”__lambda_func”, 所以匿名函数内会输入__lambda_func, 而由于最初用”\000_lambda_” . count(anonymous_functions)++重定名了函数表中的”__lambda_func”函数, 所以可经由过程”\000_lambda_” . count(anonymous_functions)++挪用这个匿名函数.
为了证明这一点, 可以将create_function的前往值dump出来检查.
而在PHP5.3宣布的时分, 个中有一条new feature就是撑持闭包/Lambda Function, 我第一反响是觉得zval新增了一个IS_FUNCTION, 但实践上是机关了一个PHP5.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)
?>
而PHP5.3中对闭包的撑持, 也仅仅是把要坚持的内部变量, 做为Closure对象的”Static属性”(并非通俗意义上的可遍历/会见的属性).
//php-5.3.0
$b = "laruence";
$func = function($a) use($b) {};
var_dump($func);
/* 输入:
object(Closure)#1 (2) {
["static"]=>
array(1) {
["b"]=>
string(8) "laruence"
}
["parameter"]=>
array(1) {
["$a"]=>
string(10) "<required>"
}
}
*/
这个完成, 团体以为和JS对闭包的撑持比起来, 仍是有些太粗陋了~
http://www.laruence.com/2010/06/20/1602.html
完成一个功能齐全的动态站点 |
|