>  기사  >  백엔드 개발  >  PHP의 콜백 함수 및 익명 함수

PHP의 콜백 함수 및 익명 함수

高洛峰
高洛峰원래의
2016-11-15 15:25:261021검색

베개책

항상 경외심을 가지세요.

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,介绍了几个用法~希望对大家有帮助,如果有问题,欢迎指出,如果您喜欢,可以点下推荐~


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.