베개책
항상 경외심을 가지세요.
PHP의 콜백 함수와 익명 함수
머리말
얼마전 회사에서 너무 바빠서 매일 퇴근하면 머리가 무겁더군요. 토요일, 일요일에는 여러가지 일이 있어서 타이핑을 시작하기가 싫어서 앞으로는 별로 바쁘지 않을 것 같아서 블로그를 시작하겠습니다. 나의 수확물을 쓰고, 요약하고, 공유할 시간을 가지세요. 팔로우를 환영합니다.
콜백 함수와 익명 함수
JS에서는 콜백 함수와 클로저를 사용하여 이벤트 메커니즘을 완성하고 많은 복잡한 작업을 수행할 수 있습니다. PHP에서는 일반적으로 사용되지 않습니다. 오늘은 PHP의 콜백 함수와 익명 함수에 대해 이야기하겠습니다.
콜백 함수
콜백 함수: 콜백(즉, 콜백은 메인 함수에 의해 호출되고 작동된 후 메인 함수로 돌아갑니다), 다른 블록에 전달되는 블록을 의미합니다. 함수 매개변수를 통해 코드를 실행하고 특정 블록 코드 참조에서 실행할 수 있습니다.
일반적인 설명은 함수를 다른 함수에 매개변수로 전달하여 사용하는 것입니다. PHP에는 array_map, usort, call_user_func_array 등과 같이 "매개변수를 함수로 요구하는" 함수가 많이 있습니다. 전달된 함수를 사용하고 그 결과를 직접 메인 함수에 반환합니다. 장점은 함수를 값으로 사용하기 편리하고, 코드가 간결하고 가독성이 좋다는 점입니다.
익명 함수:
익명 함수는 이름에서 알 수 있듯이 정해진 함수 이름이 없는 함수입니다. PHP는 익명 함수와 클로저를 동일한 개념으로 취급합니다. (익명 함수는 클로저 함수라고도 합니다.) ). 물론 사용법은 변수로만 사용할 수 있습니다.
PHP에서 변수에 함수를 할당하는 방법에는 네 가지가 있습니다.
우리가 자주 사용하는 방법: 함수는 외부에서 정의되거나 PHP에 내장되어 있으며, 함수 이름은 직접 문자열로 사용됩니다. 매개변수가 전달됩니다. 참고: 클래스 정적 함수인 경우 CLASS::FUNC_NAME으로 전달됩니다.
create_function($args, $func_code);를 사용하여 함수 이름을 반환하는 함수를 만듭니다. $func_code는 코드 본문이고 $args는 ','로 구분된 매개변수 문자열입니다.
직접 할당: $func_name = function($arg){statement}
익명 함수 사용 direct , 특정 변수 값을 할당하지 않고 매개변수에서 직접 함수를 정의합니다.
첫 번째 방법은 일반적으로 사용되며 더 이상 언급되지 않습니다. 두 번째 방법도 eval() 방법과 유사합니다. by PHP 공식적인 방법은 권장되지 않으며 정의가 너무 직관적이지 않습니다. 테스트 외에는 다른 곳에서 사용하지 않았으므로 언급하지 않겠습니다. 여기서는 세 번째와 네 번째 사용법에 중점을 둡니다.
후자의 두 가지에 의해 생성된 함수는 익명 함수, 즉 세 번째 할당 방법으로 생성된 함수는 매우 유연합니다. 변수를 통해. is_callable($func_name)을 사용하여 이 함수를 호출할 수 있는지 테스트하거나 $func_name($var)을 통해 직접 호출할 수 있습니다. 네 번째 방법으로 생성된 함수는 JS의 콜백 함수와 더 유사하며 그렇지 않습니다. 변수 할당이 필요합니다.
또 다른 특별한 소개는 함수를 정의할 때 상위 범위의 변수를 참조하는 데 사용할 수 있는 키워드입니다. function($arg) use($outside_arg; ) { function_statement} . 그 중 $outside_arg는 상위 스코프의 변수로 function_statement에서 사용할 수 있습니다.
이 사용법은 "매개변수 값의 갯수를 결정합니다"라는 콜백 함수에서 사용됩니다. 예를 들어 usort에서는 $callback의 매개변수 값이 두 개의 항목이어야 하지만 정렬에 영향을 주기 위해 다른 매개변수를 도입해야 하는 경우에는 어떻게 될까요? use() 키워드를 사용하면 내부 사용을 위해 $callback에 새 변수를 도입하는 것이 매우 편리합니다.
array_map/array_filter/array_walk:
이 세 함수의 실행 논리는 다음 코드와 유사하게 상대적으로 유사하므로 이 세 함수를 함께 사용하세요.
$result = []; foreach($vars as $key=>$val){ $item = callback(); $result[] = $item; } return $result;
array_walk($vars, $callback)
콜백은 다음과 같아야 합니다.
$callback = function(&$val, $key[, $arg]){ doSomething($val); }
array_walk는 실행 성공 여부를 부울 값으로 반환합니다. $value에 참조 기호를 추가하면 함수 내의 $value 값을 변경하여 $vars 배열을 변경하는 효과를 얻을 수 있습니다. $callback에는 두 개의 매개변수가 필요하므로 array_walk는 strtolower/array_filter와 같은 $callback을 전달할 수 없습니다. 비슷한 기능을 수행하려면 array_map()을 사용하여 다음에 설명할 수 있습니다.
array_walk_recursive($arr, $callback);
반환 값 및 실행 메커니즘은 array_walk와 유사합니다.
콜백은 다음과 동일합니다. array_walk와 차이점은 $val이 배열인 경우 함수는 $val을 아래쪽으로 재귀적으로 처리한다는 점입니다. 이 경우 $val은 배열의 $key이므로 무시됩니다.
array_filter($vars, $callback, $flag);
해당 $callback은 다음과 유사합니다.
$callback = function($var){ return true or false; }
array_filter $callback이 실행될 때 false를 반환하는 항목을 필터링하고, array_filter는 필터링이 완료된 후 배열을 반환합니다.
세 번째 매개변수 $flag는 콜백 매개변수 $var의 값을 결정하지만 이는 PHP 상위 버전의 기능일 수 있습니다. My PHP5.5.3에서는 이를 지원하지 않습니다. . 여러분이 직접 테스트해 보실 수 있습니다. 기본적으로 배열의 각 항목 값이 전달됩니다. 플래그가 ARRAY_FILTER_USE_KEY이면 배열의 각 항목의 키가 전달되고 ARRAY_FILTER_USE_BOTH는 키와 값에 전달됩니다. 🎜>
array_map($callback, &$ var_as [,$var_bs...]);
$callback은 다음과 유사합니다.
$callback = function($var_a[, $var_b...]){ doSomething($var_a, $var_b); }
返回$var_as经过callback处理后的数组(会改变原数组);如果有多个数组的时候将两个数组同样顺序的项目传入处理,执行次数为参数数组中项目最多的个数;
usort/array_reduce
把这两个函数放在一块,因为他们的执行机制都有些特殊。
usort(&$vars, $callback)
$callback应该如下:
callback = function($left, $right){ $res = compare($left, $right); return $res; }
usort返回执行成功与否,bool值。用户自定义方法 比较$left 和 $right,其中$left和$right是$vars中的任意两项;
$left > $right时返回 正整数, $left < $right时返回 负整数, $left = $right时返回0;
$vars中的元素会被取出会被由小到大升序排序。 想实现降序排列,将$callback的返回值反一下就行了。
array_reduce($vars ,$callable [, mixed $initial = NULL])
$callback应该如下:
$callback = function($initial, $var){ $initial = calculate($initail, $var); return $initial; }
初始值$initial默认为null,返回经过迭代后的initial;一定要将$initial返回,这样才能不停地改变$initial的值,实现迭代的效果。
这里顺便说一下map和reduce的不同:
map:将数组中的成员遍历处理,每次返回处理后的一个值,最后结果值为所有处理后值组成的多项数组;
reduce:遍历数组成员,每次使用数组成员结合初始值处理,并将初始值返回,即使用上一次执行的结果,配合下一次的输入继续产生结果,结果值为一项;
call_user_func/call_user_func_array
call_user_func[_array]($callback, $param)
$callback形如:
$callback = function($param){ $result = statement(); return $result; }
返回值多种,具体看$callback。
可用此函数实现PHP的事件机制,其实并不高深,在判断条件达成,或程序执行到某一步后 call_user_func()就OK了。这个我在之前的博客中也有介绍到:搭建自己的PHP框架心得(二)
总结
其实以上$callback不用单独定义并使用变量引用,使用上面说过的第四种函数定义方式,直接在函数内定义,使用‘完全’匿名函数就行了。 如:
usort($records, function mySortFunc($arg) use ($order){ func_statement; });
是不是逼格满满呢?
OK,介绍了几个用法~希望对大家有帮助,如果有问题,欢迎指出,如果您喜欢,可以点下推荐~