Cet article vous présentera comment détecter si une classe peut être traversée par foreach en PHP. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.
En PHP, nous pouvons facilement déterminer le type d'une variable, et nous pouvons également facilement déterminer la longueur d'un tableau pour déterminer si le tableau peut être parcouru. Et les cours ? Comment savoir si cette classe peut être parcourue via foreach ? En fait, PHP nous fournit déjà une interface toute faite.
class Obj1 { public $v = 'V:Obj1'; private $prv = 'prv:Obj1'; } $obj1 = new Obj1(); echo $obj1 instanceof Traversable ? 'yes' : 'no', PHP_EOL; // no class Obj2 implements IteratorAggregate { public $v = 'V:Obj2'; private $prv = 'prv:Obj2'; public function getIterator() { return new ArrayIterator([ 'v' => $this->v, 'prv' => $this->prv, ]); } } $obj2 = new Obj2(); echo $obj2 instanceof Traversable ? 'yes' : 'no', PHP_EOL; // yes
Comme le montre l'exemple ci-dessus, chaque $obj1 ne peut pas être jugé par Traversable, il ne peut donc pas être parcouru. Le deuxième $obj2 implémente l'interface itérateur, et cet objet peut être jugé via Traversable. Dans le manuel PHP, l'interface Traversable est l'interface utilisée pour détecter si une classe peut être parcourue par foreach.
Cette interface a plusieurs fonctionnalités :
Les classes intégrées qui implémentent cette interface peuvent utiliser foreach pour la traversée sans implémenter l'interface IteratorAggregate ou Iterator.
Il s'agit d'une interface de moteur interne qui ne peut pas être implémentée dans les scripts PHP. L'interface IteratorAggregate ou Iterator peut être utilisée à la place.
C'est-à-dire que cette interface ne nous oblige pas à l'implémenter manuellement. Nous avons seulement besoin que notre classe implémente l'interface liée à l'itérateur pour réussir la vérification de cette interface. Si nous implémentons cette interface seule, une erreur sera signalée et nous serons invités à implémenter l'interface IteratorAggregate ou Iterator.
// Fatal error: Class ImplTraversable must implement interface Traversable as part of either Iterator or IteratorAggregate in Unknown class ImplTraversable implements Traversable{ }
En fait, dans l'article précédent, nous avons vérifié que l'objet peut être parcouru, et il peut être parcouru par foreach sans implémenter d'interface itérateur. Il imprime toutes les propriétés publiques.
// foreach foreach ($obj1 as $o1) { echo $o1, PHP_EOL; } foreach ($obj2 as $o2) { echo $o2, PHP_EOL; } // V:Obj1 // V:Obj2 // prv:Obj2
Autant dire que le rôle de cette interface Traversable n'est pas évident en utilisation réelle. Je pense que la plupart d'entre nous n'ont jamais utilisé cette interface pour déterminer si une classe peut être parcourue.
Mais comme nous pouvons le voir dans l'exemple ci-dessus, les itérateurs peuvent personnaliser ce que nous devons produire. Relativement parlant, il est plus flexible et contrôlable que la traversée directe d'objets. De plus, l'interface Traversable ne peut pas porter de jugement si le tableau est forcé vers un objet.
$arr = [1, 2, 3, 4]; $obj3 = (object) $arr; echo $obj3 instanceof Traversable ? 'yes' : 'no', PHP_EOL; // no foreach ($obj3 as $o3) { echo $o3, PHP_EOL; }
En fait, le tableau lui-même est un objet itérable naturel. Bien que la coercition de type soit effectuée ici, il est en fait plus approprié de considérer l'objet de coercition de tableau comme un objet qui implémente un itérateur par défaut. Bien entendu, la plus grande importance de ce type d’interface réside dans les spécifications du code et les inspections obligatoires.
Code de test :
https://github.com/zhangyue0503/dev-blog/blob/master/php/202003/source/%E5%9C%A8PHP%E4%B8%AD%E6%A3%80%E6%B5%8B%E4%B8%80%E4%B8%AA%E7%B1%BB%E6%98%AF%E5%90%A6%E5%8F%AF%E4%BB%A5%E8%A2%ABforeach%E9%81%8D%E5%8E%86.php
Apprentissage recommandé : Tutoriel vidéo 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!