ホームページ >バックエンド開発 >PHPの問題 >PHPコールバックを理解する方法

PHPコールバックを理解する方法

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼オリジナル
2019-08-29 10:35:532843ブラウズ

PHPコールバックを理解する方法

コールバック関数 callback

非同期リクエストが js で処理されることが多いことは、通常の関数を使用するとよく知られています。関数は、非同期リクエストの完了後に呼び出されることが保証されていない場合があります。そこでコールバック関数があり、特にファイル処理やAjax処理中にコールバック関数は非常に便利です。

関数 call_user_func()

mixed call_user_func ( callable $callback [,mixed $parameter [,mixed $… ]] )

return を返します。複合型の値は、実際にはコールバック関数によって返される値です。

callable $callback コールバック関数には、関数名、配列、または文字列を指定できます。

mixed $parameter パラメータ関数の、順次表示

デモの使用方法を紹介します

demo1: callback php function string form

<?php
$data = array("name"=>"callback" , "value"=>"test");
$rs1 = http_build_query($data);      //直接调用php函数
$rs2  = call_user_func("http_build_query",$data); //使用回调函数
echo $rs1;  //name=callback&value=test
echo "<br />";
echo $rs2;  //name=callback&value=test
// 这里需要注意的是,参数1必须是可使用的函数可以通过function_exists()返回true的函数,这里提醒isset,empty,is_null 
等认为的常用函数实际上是一个操作符.并不能算函数。

関連する推奨事項: "PHP 入門チュートリアル>>

demo2: コールバック php 関数関数名変数形式

<?php
//自定义函数
function myUrldecode($str){
    return urldecode($str);
}
$data = array("name"=>"callback" , "value"=>"天才");
$str  = http_build_query($data); 
$rs1  = urldecode($str);      //urlencode编码
$rs2  = call_user_func(myUrldecode,$str);
echo $rs1;  //name=callback&value=天才
echo "<br />";
echo $rs2;  //name=callback&value=天才
//这里我们可以看到,我们直接使用函数的名称也是可以的,不需要带引号字符串。
?>

demo3: コールバック クラス メソッド配列形式

<?php 
class MyClass{
    private $demo = "test";
    function myUrldecode($str){
        return urldecode($str);
    }
    static  function myUrlencode($str){
        return urlencode($str) ;
    }
}
$str = "?query=/test/demo1";
$encode  = call_user_func(array(MyClass,"myUrlencode"),$str);
//直接使用类的静态方法 将字符串进行url编码 不再是字符串或者函数名,而是一个数组格式,第一个项表示类名,第二个项则表示方
法名。 第一项可以为类的引用地址,第二项为静态方法名称
$decode  = call_user_func(array("MyClass","myUrlencode"),$encode);
//同样是使用类的方法,不过调用的是普通方法名称。
echo $encode;  //%3Fquery%3D%2Ftest%2Fdemo1
echo "<br />"; //?query=/test/demo1
echo $decode;
//注意 使用方法名也具有作用域的概念,即private protected 和 public,通常回调类方法都只能调用publi 和默认作用域的 方法。
//同时如果是普通方法,并且内部使用了$this变量,那么进行调用是无法成功的.
?>

demo4: コールバック クラス メソッドの文字列形式

<?php
class MyClass{
    private $demo = "test";
    function myUrldecode($str){
        return urldecode($str);
    }
    private function myUrldecode2($str){
    return urldecode($str);
    }
    static  function myUrlencode($str){
        return urlencode($str) ;
    }
}
$str = "?query=/test/demo1";
  $encode  = call_user_func("MyClass::myUrlencode",$str);
  $decode  = call_user_func("MyClass::myUrldecode",$encode);
  echo $encode; //  %3Fquery%3D%2Ftest%2Fdemo1
  echo "<br />";
  echo $decode; //  ?query=/test/demo1
  $encode2  = call_user_func("MyClass::myUrlencode2",$str);
  var_dump($encode2);  // null
//如果直接使用字符串的方法的话,那么必须在类和方法名中添加::作为分割。
//这里我们发现不是静态方法也可以用::进行调用
//这里进行了一个测试,发现调用private 作用域的方法返回的是一个null值,说明确实存在作用域的关系
?>

demo5: コールバック オブジェクト メソッドの配列形式

<?php
class MyClass{
    private $demo = "test";
    function myUrldecode($str){
        return urldecode($str)  ."-" .$this->demo ; //调用内部的this作用域
    }
    static  function myUrlencode($str){
        return urlencode($str);
    }
}
 $str = "?query=/test/demo1";
 $class =  new MyClass();
 $encode  = call_user_func(array($class,"myUrlencode"),$str);
 $decode  = call_user_func(array($class,"myUrldecode"),$str);
 echo $encode; //%3Fquery%3D%2Ftest%2Fdemo1
 echo "<br />";
 echo $decode; //?query=/test/demo1-test
 //很明显,如果使用对象做为回调函数,内部的private 属性和方法也可以使用,但是对外的方法必须为默认或者 public类型
 //对象数组方式第一个选项必须为一个对象
?>

渡されるパラメータが固定されていない場合があるため、call_user_func() を使用すると問題が発生することがあります。このとき、call_user_func_array() メソッドを使用できます。使用方法はほとんど同じですが、パラメータは少し異なります。

関数 call_user_func_array()

demo1: コールバック php 関数の不定パラメータ

<?php 
   $record1 = array(
            &#39;id&#39; => 2135,
    );
    $record2 = array(
        &#39;first_name&#39; => &#39;Sally&#39;,
    );
    $record3 = array(
        &#39;last_name&#39; => &#39;Jones&#39;,
    );
$return  = array_merge($record1,$record2,$record3);
//如果使用回调函数,则如下
$return  = call_user_func_array("array_merge", array($record1,$record2,$record3));
print_r($return); //Array ( [id] => 2135 [first_name] => Sally [last_name] => Jones )
//一些特别的函数允许你有不固定的参数,如果你还将它作为回调函数,则可以使用这个方法进行调用.
?>

tips1 かどうかを判断する方法これは呼び出し可能な関数

bool is_callable ( callable $name [, bool $syntax_only = false [, string &$callable_name ]] )

name

になりますコールバックをチェックしました。

syntax_only

TRUE に設定すると、この関数は名前が関数またはメソッドであるかどうかのみを検証します。

callable_name

「呼び出し可能な名前」を受け入れます。

return

name が呼び出し可能な場合は TRUE を返し、それ以外の場合は FALSE を返します。

<?php
// is_callable(); 
$bool = is_callable(urlencode);  // true
$bool = is_callable(urlencode,false);  // true
$bool = is_callable(urlencode,true);  // true
$bool = is_callable("urlencode",false,$callable_name1);
// string urlencode
$bool = is_callable("urldecode",true,$callable_name2); 
// string urldecode 即使不存在回调函数也会返回true
?>

tips2 js

<?php
//这里指的是非客户端php脚本
function sum($first,$second){
$args = func_get_args(); //获取列表  
//func_get_arg($index) 则获取指定的位置的参数
$len  = func_num_args(); //获取长度
$sum = 0 ; 
foreach($args as $key=>$val){
 $sum += (int) $val; 
}
return $sum;
}
$rs = sum(1,2,3,4,5);
var_dump($rs); //  int 15
//注意: 在sum函数中修改了$first,$second的变量,同时又不是引用对象 变量的话,则不会修改
?>
の引数と同様に、関数のパラメーターを取得します。

以上がPHPコールバックを理解する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。