Heim > Backend-Entwicklung > PHP-Tutorial > PHP-Erweiterungsentwicklung mit PHP-CPP: objektorientierter Code

PHP-Erweiterungsentwicklung mit PHP-CPP: objektorientierter Code

Christopher Nolan
Freigeben: 2025-02-21 09:17:13
Original
140 Leute haben es durchsucht

PHP Extension Development with PHP-CPP: Object Oriented Code

Dieser Artikel setzt die Erforschung von PHP-Erweiterungen mithilfe von PHP-CPP fort und konzentriert sich auf objektorientierte Merkmale. Wir erstellen eine Complex Zahlenklasse, um die Funktionen der Bibliothek zu veranschaulichen.

Zu Beginn werden wir die PHP-CPP-Projektvorlage anpassen. Benennen Sie yourtextension.ini in complex.ini um und aktualisieren Sie den Inhalt in extension=complex.so. Ändern Sie die Makefile wie folgt:

NAME                =   complex
INI_DIR             =   /etc/php5/cli/conf.d
Nach dem Login kopieren

Als nächstes definieren wir die Complex -Klasse in main.cpp.

Schlüsselkonzepte:

  • PHP-CPP vereinfacht die objektorientierte PHP-Erweiterungsentwicklung mithilfe der vertrauten C-Syntax.
  • Die Complex -Klass-Präsentationen C- und PHP-Konstruktoren/-Destruktoren für die nahtlose Integration.
  • Methoden wie mod() und add() Demonstration der Methodenregistrierung, sodass PHP -Skripte die C -Klasse -Funktionalität direkt verwenden können.
  • Php "Magic Methods" (z. B. __toString()) Verbessert die Interaktion mit Objekten in PHP -Skripten.
  • Der Artikel enthält eine vollständige Anleitung zum Konfigurieren, Kompilieren und Testen von PHP -Erweiterungen.

C und PHP -Konstruktoren/Zerstörer:

c verwendet Konstruktoren (Funktionen mit dem Klassennamen, keinen Rückgabetyp) und Destruktoren (Klassenname, das mit ~ vorangestellt ist, ohne Rückgabe -Typ, keine Parameter). PHP verwendet __construct() und __destruct(). PHP-CPP unterstützt beide:

class Complex : public Php::Base {
private:
    double r = 0, i = 0;

public:
    Complex() {}
    virtual ~Complex() {}

    Php::Value getReal() { return r; }
    Php::Value getImage() { return i; }

    void __construct(Php::Parameters &params) {
        if (params.size() == 2) {
            r = params[0];
            i = params[1];
        } else {
            r = 0;
            i = 0;
        }
    }
    // ... other methods ...
};
Nach dem Login kopieren

Wichtige Punkte:

  1. Alle Klassen müssen von Php::Base.
  2. erben
  3. Sowohl C- als auch PHP-Konstruktoren werden implementiert.
  4. getReal() und getImage() Zugriff auf private Mitglieder.
  5. Der PHP -Konstruktor behandelt die Initialisierung.

mod() Methode:

Diese Methode berechnet den Modul einer komplexen Zahl:

Php::Value mod() const {
    return (double)sqrt(r * r + i * i);
}
Nach dem Login kopieren

Denken Sie daran, <cmath> für sqrt() einzuschließen. PHP-CPP unterstützt bestimmte Signaturen der Mitgliederfunktion (siehe Artikel für Einzelheiten).

add() Methode:

zwei komplexe Zahlen hinzufügen:

Php::Value add(Php::Parameters &params) {
    Php::Value t = params[0];
    Complex *a = (Complex *)t.implementation();

    r += (double)a->getReal();
    i += (double)a->getImage();

    return this;
}
Nach dem Login kopieren

t.implementation() ist entscheidend, um ein Php::Value auf sein zugrunde liegendes C -Objekt zu werfen.

__toString() Methode:

für benutzerfreundliche Ausgabe:

Php::Value __toString() {
    std::ostringstream os;
    os << r;
    if (i >= 0) os << "+";
    os << i << "i";
    return os.str();
}
Nach dem Login kopieren

integrieren <sstream> für String Manipulation.

Funktion Registrierung:

Registrieren Sie die Klasse und ihre Methoden:

extern "C" {
    PHPCPP_EXPORT void *get_module() {
        static Php::Extension myExtension("complex", "1.0");
        Php::Class<Complex> complex("Complex");
        complex.method("mod", &Complex::mod, {});
        complex.method("__construct", &Complex::__construct);
        complex.method("add", &Complex::add, {Php::ByVal("op", "Complex", false, true)});
        myExtension.add(std::move(complex));
        return myExtension;
    }
}
Nach dem Login kopieren

Zusammenstellung, Installation und Test:

kompilieren und installieren Sie mit make && sudo make install. Testen Sie mit PHP -Code (siehe den ursprünglichen Artikel für Beispiele).

Namespace -Kapselung:

Die Klasse in einen Namespace einwickelt (trComplex in diesem Beispiel) erfordert minimale Änderungen (siehe den Originalartikel für Einzelheiten). Der Schlüssel ist das Anpassung des Namespace in der Funktion get_module() und verwendet den voll qualifizierten Namen im PHP -Code.

Schlussfolgerung:

PHP-CPP bietet einen optimierten Ansatz zum Erstellen von PHP-Erweiterungen. Während Dokumentationsverbesserungen vorgeschlagen werden, machen die Benutzerfreundlichkeit und die Funktionen es zu einem wertvollen Tool. Der Artikel enthält einen umfassenden Leitfaden, der wesentliche Aspekte der objektorientierten PHP-Erweiterungsentwicklung abdeckt.

Das obige ist der detaillierte Inhalt vonPHP-Erweiterungsentwicklung mit PHP-CPP: objektorientierter Code. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage