Countable
und ArrayAccess
in Iterator
Php ermöglichen es Objekten, count()
Methoden zu übergeben, wie Karten zuzugriff und über Sets zu iterieren. Diese Schnittstellen können verwendet werden, um dynamischere und interaktivere Objekte zu erstellen, wie z. Als Programmierer, der jeden Tag verschiedene Programmiersprachen verwendet, lerne ich gerne verschiedene Dinge in anderen Sprachen und versuche, die gleiche Funktionalität in PHP zu implementieren. Besonders gefällt mir die Funktion in Python, wie native Datentypen in benutzerdefinierten Klassen simulieren.
Zum Beispiel diese Mitgliedslistenklasse:
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
Durch die Implementierung der __iter__
-Methode können Sie die Daten in solchen Instanzen wie der Iteration einer Liste (Array in PHP) iterieren:
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
__contains__
Mitgliedschaftstest muss nur implementiert werden
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
Ich denke, es wäre großartig, wenn ich in einer Instanz einer benutzerdefinierten Klasse Folgendes in PHP machen könnte (nicht nur ein Array):
isset($myObject["test"]);
PHP ermöglicht es uns, dies mithilfe einer Array -Schnittstelle zu erreichen.
Behandeln Sie eine Schnittstelle als Vertrag für die angegebene Klasse, um Methoden zu enthalten.
interface Multiplier { public function multiply($num1, $num2); }
multiply
Jede Klasse, die diese Schnittstelle verwendet, muss diese implements
-Methode haben. Es gibt ein Schlüsselwort, das angibt, dass die Klasse diesen Vertrag erfüllt:
class SmartMultiplier implements Multiplier { public function multiply($num1, $num2) { return $num1 * $num2; } }
multiply
Solange der Vertrag erfüllt ist, ist die Implementierungsmethode irrelevant. Eine andere Möglichkeit, die Methode
class NotSoSmartMultiplier implements Multiplier { public function multiply($num1, $num2) { $product = $num1; for ($i = 1; $i < $num2; $i++) { $product += $num1; } return $product; } }
PHP bietet eine Bibliothek vordefinierter Schnittstellen, die unsere Objekte ähnlich wie bei der Implementierung dieser Schnittstellen in einer Klasse machen kann.
Einige dieser Schnittstellen sind in vordefinierten Schnittstellen und Klassenlisten enthalten, einige sind in der Standard -PHP -Bibliothek (SPL) enthalten.
$_GET
Wenn diese Begriffe einschüchternd klingen, mach dir keine Sorgen. Sie haben früher $_GET
verwendet. ist eine Sprachstruktur, die als vordefinierte
Andererseits ist SPL nur
Eine Sammlung von Schnittstellen und Klassen zur Lösung gemeinsamer Probleme.
Was wir jetzt tun müssen, ist die tatsächliche Anwendung dieser Schnittstellen zu sehen. Lassen Sie uns darauf eingraben!
Wir erstellen eine Twitter -Timeline -Klasse, <🎜>
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
kann in der Lage sein, die Anzahl der Tweets zu berechnen,
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
Schleifen Sie durch sie,
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
und erhalten Sie den Tweet über die Tweet -ID
isset($myObject["test"]);
Genau wie wir in einem normalen Array sind!
Wir müssen jedoch zuerst einige Probleme lösen. Wenn Sie noch kein Twitter -Konto haben, erstellen Sie zuerst eines. Registrieren Sie jetzt ein Entwicklerkonto und generieren Sie ein Zugriffstoken und ein Schlüssel.
Download oder klonen Sie den Code von GitHub und klonen Sie im Quellordner composer install
. Wenn Sie mit Komponist nicht vertraut sind, lesen Sie frühere Artikel von SitePoint. Öffnen Sie die Datei index.php
und fügen Sie die erforderlichen OAuth -Daten hinzu.
Countable
Schnittstelle Countable
Die Schnittstelle ist wahrscheinlich die selbsterndste. Implementieren Sie einfach die count
-Methode und Sie können das Objekt an die count()
-Methode übergeben.
Wir können die Anzahl der Tweets von Benutzern erhalten, indem wir eine GET -Anfrage auf "/user/show" durchführen.
interface Multiplier { public function multiply($num1, $num2); }
ArrayAccess
Schnittstelle Wir werden nun die Schwierigkeit erhöhen, indem wir eine interessantere Schnittstelle lernen.
Nach der Implementierung ermöglicht, dass unsere Objekte wie Karten zugegriffen werden können, was genau ihre Essenz ist. Die zu erzielende Methode ist ArrayAccess
class SmartMultiplier implements Multiplier { public function multiply($num1, $num2) { return $num1 * $num2; } }
isset
Um dies zu tun, müssen wir nur eine Get -Anfrage an die Tweet -ID ausführen.
class NotSoSmartMultiplier implements Multiplier { public function multiply($num1, $num2) { $product = $num1; for ($i = 1; $i < $num2; $i++) { $product += $num1; } return $product; } }
Besser noch, wir können das obige auch für
verwenden und$tweets = new Timeline("jeunito");
wiederum aufrufen. offsetGet
offsetExists
Mit offsetGet
können wir es auch mit der Tweet -ID löschen, aber ich werde dies für Sie implementieren.
Leider macht das Erreichen von offsetUnset
nicht viel Sinn. Für so etwas ist die einfache Lösung, eine benutzerdefinierte Ausnahme wie
offsetSet
UnsupportedOperationException
Schnittstelle
Iterator
-Schinschnittstelle ist hier sehr nützlich, da ich nicht glaube, dass es eine bessere Möglichkeit gibt, die Details der Remote -Sammlungs -Pagination zu verkapulieren, als über Timeline -Objekte wie die Iteration von normalen Arrays zu iterieren. Zunächst muss die folgende Methode implementiert werden: Iterator
Wir können die obige Methode explizit verwenden, um unsere Zeitachse zu durchlaufen, wie unten gezeigt:
count($tweets);
Aber warum tun Sie das, wenn Sie können:
foreach ($tweets as $tweet) { echo $tweet; }
In unserem Beispiel werden wir die Tweets in der Zeitleiste durchlaufen, indem wir Tweet -Blöcke in chronologischer Reihenfolge abrufen und in einem Puffer speichern. Wir werden über diesen Puffer iterieren, bis er abgelaufen ist, und dann verwenden wir die ID des letzten Tweets als Offset, um eine weitere Reihe von Tweets zu erhalten.
Zunächst hatten wir keine Tweets, und hier kommt die rewind
-Methode ins Spiel: Holen Sie sich die neuesten 10 Tweets, um den Offset von der Stelle zu starten, an der wir die nächsten 10 Tweets erhalten können.
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
valid()
-Methode wird nur verwendet, um anzuzeigen, ob die Schleife fortgesetzt wird. Dies kann durch Überprüfung erfolgen, ob unser Tweet -Puffer leer ist:
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
key()
und current()
geben einfach die Schlüssel und Werte des aktuellen Tweets in unserer Iteration zurück. Für unsere Zwecke erhalten wir einfach die Tweet -ID und den Text des neuesten Tweets aus dem Puffer.
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
zuletzt next
Methode. Hier werden wir vom Kopf des Puffers entlassen, um das nächste Element zum Iterieren zu bringen. Wenn wir dann auf dem letzten Element des Puffers stehen, werden wir sicherstellen, dass die nächsten Tweets -Set erhalten.
isset($myObject["test"]);
Wir sind fertig! Dies ist eine sehr grundlegende Implementierung von Schleifen durch Benutzer -Tweets. Es gibt mehr Dinge, die getan werden können, wie z. B. lokaler Cache, um API -Anrufe zu retten es funktioniert noch.
Aber jetzt können Sie beobachten, wie unsere Timeline -Objekte funktionieren, indem Sie in der Befehlszeile php index.php
ausgeführt werden.
Die Vorteile der Schnittstelle sind zweifach. Sie ermöglichen es uns, Implementierungsdetails zu verkörpern und syntaktischen Zucker bereitzustellen, die beide in jeder Anwendung sehr nützlich sind, die Interoperabilität erfordert. Wenn Sie Fragen oder Kommentare haben, lassen Sie sie bitte im Kommentarbereich unten!
Das obige ist der detaillierte Inhalt vonSpaß mit Array -Schnittstellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!