首頁 > 後端開發 > PHP問題 > 簡單理解call_user_func和call_user_func_array兩個函數

簡單理解call_user_func和call_user_func_array兩個函數

步履不停
發布: 2023-02-23 06:40:01
原創
1915 人瀏覽過

簡單理解call_user_func和call_user_func_array兩個函數

call_user_func():呼叫一個回呼函數處理字串,
  可以用匿名函數,可以用有名函數,可以傳遞類別的方法,
  用有名函數時,只要傳函數的名稱
  用類別的方法時,要傳類別的名稱和方法名稱
  傳遞的第一個參數必須為函數名,或是匿名函數,或是方法
  其他參數,可傳一個參數,或多個參數,這些參數會自動傳遞到回呼函數中
  而回調函數,可以透過傳參,取得這些參數
  傳回回呼函數處理後的結果

  ①傳遞函數名,透過回呼函數的形參取得call_user_func傳參數的情況

<?php
//先引用后增加
function _call($call){
    //通过传参获取call_user_func传过来的参数
    echo $call++,&#39;<br/>&#39;;
    echo $call++,"<br/>";
}
//上面回调函数没有返回值,所以,这里就没有返回值,_call为上面的函数的名称
$re = call_user_func(&#39;_call&#39;,1);
//实验结果为 null,符合上面的结论
var_dump($re);
登入後複製

  ②呼叫匿名函數傳參的情況

#
<?php
//先增加后引用
call_user_func(function($call){
    echo ++$call,&#39;<br/>&#39;;
    echo ++$call,&#39;<br/>&#39;;
},1);//传给匿名函数的参数为···1···,执行的结果为2,3
登入後複製

  ③回呼函數是匿名函數,且匿名函數不設參數,透過其他方式取得參數的情況

$arg1 = &#39;first&#39;;
$arg2 = &#39;two&#39;;
$return = call_user_func(function(){
    $arg = func_get_arg(0); //func_get_arg函数作用:获取函数的第几个参数,必须要有参数,参数必须为函数参数的偏移量,0代表第一个参数
    $args = func_get_args();//func_get_args的作用:获取函数所有的参数
    if(func_num_args() == 1){//func_num_args函数的作用:获取函数参数的个数,注意,假如函数没有传参,该函数返回0
        return $args[0];
    }else{
        //用|把函数的参数组织成字符串
        return implode(&#39;|&#39;,$args);
    }
},$arg1,$arg2);
var_dump($return);
登入後複製

  ④呼叫···沒有命名空間· ··的······類別方法······的情況

<?php
class Func{
    //静态方法
    static public function _func(){
        $str =  &#39;THE CLASS NAME IS &#39;.__CLASS__.&#39; AND CLASS STATIC METHOD IS &#39;.__METHOD__;
        if(func_num_args()){
            //获取函数参数,获取参数也可以通过给方法设置形参来获取,这里只是没给方法设置形参获取参数的情况
            $arg = func_get_arg(0);
            return $str.&#39; and argument is &#39;.$arg;
        }else{
            return $str;
        }
    }
    //普通方法
    public function __func($num){
        return $num ? $num+1:$num;
    }
}
//传递类的静态方法,有两种方式
//(1)种,传递····类名::方法名····
var_dump(call_user_func("Func::_func",&#39;hell world&#39;));//这里传递参数
//(2)种,传递类名和方法名的数组
var_dump(call_user_func(array(&#39;Func&#39;,&#39;_func&#39;)));//这里没有传参数
$num = 4;
$o = new Func;
//传递类普通方法必须用···数组···传递···该类的对象··和···方法名···
$return = call_user_func(array($o,&#39;__func&#39;),$num);
var_dump($return);
登入後複製

  ⑤呼叫·····有命名空間的·······類別方法· ········的情況

<?php
//定义类的命名空间
namespace Home;
class Space{
    //静态方法
    static public function _call($num){
        return $num +=10;
    }
    //普通方法
    public function _func(){
        return func_get_args();//返回函数的参数
    }
}
//针对静态方法,有两种调用方式
//1.可以用array(__NAMESPACE__.&#39;\类名&#39;,&#39;方法名&#39;)传递类方法,也就是:array(&#39;命名空间\类名&#39;,&#39;方法名&#39;)
$return = call_user_func(array(__NAMESPACE__.&#39;\Space&#39;,&#39;_call&#39;),10);
//2.可以用····    __NAMESPACE__.&#39;\类名::方法名&#39;    ···传递类方法,也就是:&#39;命名空间\类名::方法名&#39;
$return1 = call_user_func(&#39;Home\Space::_call&#39;,100);
var_dump($return);
var_dump($return1);
//针对普通方法,不用传入命名空间即可调用,如下
$o = new Space;
$return = call_user_func(array($o,&#39;_func&#39;),1,2,3,4,5);
var_dump($return);
登入後複製

 

#  call_user_func函數是php引用匿名函數的一種方式,php不像js那樣,可以把匿名函數賦值給變數並引用,但可以透過call_user_func函數來呼叫匿名函數,這也能做到局部變數不被全域污染,call_user_func呼叫的回呼函數不僅僅是我們自訂的函數,還可以是php處理字串的系統函數,如rtrim、explode的,在呼叫這些系統函數時,需要注意的是,call_user_func傳遞的參數必須符合系統函數的傳參順序,你自己可以試著呼叫一下,舉個例子:呼叫rtrim和explode函數。下面的範例自己試過,是可行的(php影片教學

<?php
$return = call_user_func(&#39;rtrim&#39;,&#39;sso;osoo;&#39;,&#39;;&#39;);
$return2 = call_user_func(&#39;explode&#39;,&#39;;&#39;,&#39;sso;osoo;&#39;);
var_dump($return);
var_dump($return2);
登入後複製

  與call_user_func函數類似的還有一個call_user_func_array函數,這個函數的呼叫和作用和call_user_func函數基本上一樣,不同的是,call_user_func_array函數只能傳遞兩個參數,第一個是回呼函數名,或是匿名函數,或是類別方法,第二個參數則是數組,從這裡也可以看出,其實call_user_func_array函數與call_user_func不同的是,call_user_func_array是利用回呼函數處理數組,而call_user_func則是利用回呼函數處理字串,他們兩個的根本差異就在這裡了。你自己可以嘗試的呼叫call_user_func_array()函數,因為它們的引用基本上一樣,所以關於call_user_func_array就不再多寫了。

以上是簡單理解call_user_func和call_user_func_array兩個函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板