> 백엔드 개발 > PHP 튜토리얼 > zend-framework - php如何序列化/存储闭包(Closure)

zend-framework - php如何序列化/存储闭包(Closure)

WBOY
풀어 주다: 2016-06-06 20:51:58
원래의
1228명이 탐색했습니다.

在最新的Zend Framework 2.0中,已经开始大量采用php5.3的闭包特性。可以通过在配置文件中引入闭包来初始化模块。(参看:http://packages.zendframework.com/doc...)

但是配置文件会存在缓存,格式转换等需求(php => xml),此时对于配置文件内的闭包应该如何处理? 直接序列化闭包php并不支持。

回复内容:

在最新的Zend Framework 2.0中,已经开始大量采用php5.3的闭包特性。可以通过在配置文件中引入闭包来初始化模块。(参看:http://packages.zendframework.com/doc...)

但是配置文件会存在缓存,格式转换等需求(php => xml),此时对于配置文件内的闭包应该如何处理? 直接序列化闭包php并不支持。

没用过Zend,不过我想ZF2只不过是简单的把闭包函数的代码复制到不同格式的配置文件里,最后肯定都是要重新写回到PHP代码格式的缓存(可以直接运行),不然运行时去解析配置文件,效率太差。

实在需要序列化,可以用反射(Reflection),并直接操作代码文件获得上下文信息:

/**
 * 创建一个反射:
 */
$reflection = new ReflectionFunction($closure);

/**
 * 参数可以直接得到了:
 */
$params = $reflection->getParameters();

/**
 * 获得Closure的函数体和use变量,形如:
 * function($arg1, $arg2, ...) use ($val1, $val2, ...) {
 *     // 要获得这个部分的代码!
 * }
 * 办法很多,你可以直接用正则、字符串查找或者Tokenizer,等等等等。
 * 比如可以先从reflection里得到函数的开始行和结束行:
 */
$startLine = $reflection->getStartLine();
$endLine = $reflection->getEndLine();
// 然后用str*这个,str*那个的函数来清理,细节不写了:
$usedVars = use变量们;
$closureBody = 函数体;

// ...
로그인 후 복사

至此params,usedVars,closureBody等等只是数组和字符串了。

관련 라벨:
php
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿