Maison  >  Article  >  développement back-end  >  Explorez les fonctions is_callable() et method_exists() en PHP

Explorez les fonctions is_callable() et method_exists() en PHP

一个新手
一个新手original
2017-09-06 16:24:331328parcourir

Dans de nombreuses applications de produits, nous pouvons souvent voir l'utilisation suivante, qui est utilisée pour vérifier si une méthode dans un objet existe.

<?php
    if (method_exists($object, &#39;SomeMethod&#39;)) {   
    $object->SomeMethod($this, TRUE); 
    }
?>

Le but de ce code est relativement facile à comprendre. Il existe un objet appelé $object Nous voulons savoir s'il a une méthode appelée SomeMethod.

Ce code semble correct et fonctionnera correctement la plupart du temps. Mais si la méthode de cet objet $object est invisible dans l’environnement d’exécution actuel, le programme peut-il toujours s’exécuter normalement ? Tout comme cette méthode de nom de fonction existe, elle vérifie simplement si la classe ou l'objet que nous fournissons a la méthode attendue. Si c'est le cas, elle renvoie TRUE. Sinon, elle renvoie FALSE. La question de la visibilité n'est pas prise en compte ici. Par conséquent, lorsque vous déterminez une méthode privée ou protégée, vous pouvez obtenir un retour correct, mais lors de l'exécution, vous recevrez un avertissement d'erreur « Erreur fatale ».

La véritable intention du code ci-dessus doit être comprise comme : pour la classe ou l'objet fourni, pouvons-nous appeler sa méthode SomeMethod dans la portée actuelle. Et c’est exactement le but de la fonction is_callable(). is_callable()La fonction reçoit un paramètre de rappel, qui peut spécifier un nom de fonction ou un tableau contenant le nom de la méthode et l'objet. Si elle peut être exécutée dans la portée actuelle, elle renvoie VRAI.

<?php
    if (is_callable(array($object, &#39;SomeMethod&#39;))) {      
        $object->SomeMethod($this, TRUE); 
    }
?>

Donnons un exemple pour illustrer la différence entre les deux

<?phpclass Foo {
    public function PublicMethod(){}    
    private function PrivateMethod(){}    
    public static function PublicStaticMethod(){}    
    private static function PrivateStaticMethod(){}
}
    $foo = new Foo();$callbacks = array(    
    array($foo, &#39;PublicMethod&#39;),    
    array($foo, &#39;PrivateMethod&#39;),    
    array($foo, &#39;PublicStaticMethod&#39;),    
    array($foo, &#39;PrivateStaticMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PublicMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PrivateMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PublicStaticMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PrivateStaticMethod&#39;),
   );
   foreach ($callbacks as $callback){
    var_dump($callback);
    var_dump(method_exists($callback[0], $callback[1]));
    var_dump(is_callable($callback));    
    echo str_repeat(&#39;-&#39;, 10);    
    echo &#39;<br />&#39;;
}

Après avoir exécuté le script ci-dessus, nous verrons clairement la différence entre les deux fonctions.

is_callable() Il existe d'autres utilisations, par exemple, ne pas vérifier la classe ou la méthode fournie, mais uniquement vérifier si la syntaxe de la fonction ou de la méthode est correcte. Comme method_exists(), is_callable() peut déclencher le chargement automatique des cours.

Si un objet a une méthode magique __call, method_exists() renverra FALSE et is_callable() renverra TRUE lors du jugement de la méthode.

<?phpclass MethodTest {
    public function __call($name, $arguments){
      echo &#39;Calling object method &#39; . $name . &#39; &#39; .implode(&#39;, &#39;, $arguments);      
      echo &#39;<br />&#39;;
    }
}$obj = new MethodTest();$obj->runtest(&#39;in object context&#39;);
var_dump(method_exists($obj,&#39;runtest&#39;));
var_dump(is_callable(array($obj,&#39;runtest&#39;)));

echo &#39;<br />&#39;;

Exécuter les résultats

Appel de la méthode objet runtest dans le contexte de l'objet
bool(false) bool(true)

Explorez les fonctions is_callable() et method_exists() en PHP

Dans de nombreuses applications de produits, nous pouvons souvent voir l'utilisation suivante, qui est utilisée pour vérifier si une méthode dans un objet existe.

<?phpif (method_exists($object, &#39;SomeMethod&#39;)) {   
    $object->SomeMethod($this, TRUE); 
}?>

Le but de ce code est relativement facile à comprendre. Il existe un objet appelé $object Nous voulons savoir s'il a une méthode appelée SomeMethod.

Ce code semble correct et fonctionnera correctement la plupart du temps. Mais si la méthode de cet objet $object est invisible dans l’environnement d’exécution actuel, le programme peut-il toujours s’exécuter normalement ? Tout comme cette méthode de nom de fonction existe, elle vérifie simplement si la classe ou l'objet que nous fournissons a la méthode attendue. Si c'est le cas, elle renvoie TRUE. Sinon, elle renvoie FALSE. La question de la visibilité n'est pas prise en compte ici. Par conséquent, lorsque vous déterminez une méthode privée ou protégée, vous pouvez obtenir un retour correct, mais lors de l'exécution, vous recevrez un avertissement d'erreur « Erreur fatale ».

La véritable intention du code ci-dessus doit être comprise comme : pour la classe ou l'objet fourni, pouvons-nous appeler sa méthode SomeMethod dans la portée actuelle. Et c’est exactement le but de la fonction is_callable(). is_callable()La fonction reçoit un paramètre de rappel, qui peut spécifier un nom de fonction ou un tableau contenant le nom de la méthode et l'objet. Si elle peut être exécutée dans la portée actuelle, elle renvoie VRAI.

<?php
    if (is_callable(array($object, &#39;SomeMethod&#39;))) {      
    $object->SomeMethod($this, TRUE); 
    }
?>

Donnons un exemple pour illustrer la différence entre les deux

<?php
    class Foo {
    public function PublicMethod(){}    
    private function PrivateMethod(){}    
    public static function PublicStaticMethod(){}    
    private static function PrivateStaticMethod(){}
}
$foo = new Foo();$callbacks = array(    
    array($foo, &#39;PublicMethod&#39;),    
    array($foo, &#39;PrivateMethod&#39;),    
    array($foo, &#39;PublicStaticMethod&#39;),    
    array($foo, &#39;PrivateStaticMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PublicMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PrivateMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PublicStaticMethod&#39;),    
    array(&#39;Foo&#39;, &#39;PrivateStaticMethod&#39;),
   );
   foreach ($callbacks as $callback){
    var_dump($callback);
    var_dump(method_exists($callback[0], $callback[1]));
    var_dump(is_callable($callback));    
    echo str_repeat(&#39;-&#39;, 10);    
    echo &#39;<br />&#39;;
}

Après avoir exécuté le script ci-dessus, nous verrons clairement la différence entre les deux fonctions.

is_callable() Il existe d'autres utilisations, par exemple, ne pas vérifier la classe ou la méthode fournie, mais uniquement vérifier si la syntaxe de la fonction ou de la méthode est correcte. Comme method_exists(), is_callable() peut déclencher le chargement automatique des cours.

Si un objet a une méthode magique __call, method_exists() renverra FALSE et is_callable() renverra TRUE lors du jugement de la méthode.

<?phpclass MethodTest {
    public function __call($name, $arguments){
      echo &#39;Calling object method &#39; . $name . &#39; &#39; .implode(&#39;, &#39;, $arguments);      
      echo &#39;<br />&#39;;
    }
}
$obj = new MethodTest();$obj->runtest(&#39;in object context&#39;);
var_dump(method_exists($obj,&#39;runtest&#39;));
var_dump(is_callable(array($obj,&#39;runtest&#39;)));
echo &#39;<br />&#39;;

Exécuter les résultats

Appel de la méthode objet runtest dans le contexte de l'objet
bool(false) bool(true)

Explorez les fonctions is_callable() et method_exists() en PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn