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

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

一个新手
Libérer: 2023-03-15 18:52:02
original
1381 Les gens l'ont consulté

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); 
    }
?>
Copier après la connexion

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); 
    }
?>
Copier après la connexion

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;;
}
Copier après la connexion

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;;
Copier après la connexion

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); 
}?>
Copier après la connexion

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); 
    }
?>
Copier après la connexion

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;;
}
Copier après la connexion

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;;
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal