Objektorientierte Programmierung in PHP
Wir können uns unser Universum aus verschiedenen Objekten wie Sonne, Erde, Mond usw. vorstellen. Ebenso können wir uns unser Auto aus verschiedenen Objekten wie Rad, Lenkung, Getriebe usw. vorstellen. Ebenso gibt es objektorientierte Programmierkonzepte, die alles als Objekt und annehmen Implementieren Sie eine Software mit verschiedenen Objekten.
Objektorientierte Konzepte
Bevor wir ins Detail gehen, definieren wir wichtige Begriffe im Zusammenhang mit der objektorientierten Programmierung.
Class- Dies ist ein vom Programmierer definierter Datentyp, der sowohl lokale Funktionen als auch lokale Daten enthält. Sie können sich eine Klasse als Vorlage vorstellen, um viele Instanzen derselben Art (oder Klasse) von Objekten zu erstellen.
Object- Eine einzelne Instanz der von einer Klasse definierten Datenstruktur. Sie definieren eine Klasse einmal und erstellen dann viele Objekte, die dazu gehören. Objekte werden auch als Instanz bezeichnet.
Member Variable- Dies sind die Variablen, die innerhalb einer Klasse definiert sind. Diese Daten sind außerhalb der Klasse unsichtbar und können über Mitgliedsfunktionen abgerufen werden. Diese Variablen werden als Attribut des Objekts bezeichnet, sobald ein Objekt erstellt wurde.
Member function - Dies sind die innerhalb einer Klasse definierten Funktionen, mit denen auf Objektdaten zugegriffen wird.
Inheritance- Wenn eine Klasse durch Erben der vorhandenen Funktion einer übergeordneten Klasse definiert wird, wird sie als Vererbung bezeichnet. Hier erbt die untergeordnete Klasse alle oder wenige Elementfunktionen und Variablen einer übergeordneten Klasse.
Parent class- Eine Klasse, die von einer anderen Klasse geerbt wird. Dies wird auch als Basisklasse oder Superklasse bezeichnet.
Child Class- Eine Klasse, die von einer anderen Klasse erbt. Dies wird auch als Unterklasse oder abgeleitete Klasse bezeichnet.
Polymorphism- Dies ist ein objektorientiertes Konzept, bei dem dieselbe Funktion für verschiedene Zwecke verwendet werden kann. Zum Beispiel bleibt der Funktionsname gleich, benötigt jedoch eine unterschiedliche Anzahl von Argumenten und kann unterschiedliche Aufgaben ausführen.
Overloading- eine Art von Polymorphismus, bei dem einige oder alle Operatoren je nach Art ihrer Argumente unterschiedliche Implementierungen haben. In ähnlicher Weise können Funktionen auch mit unterschiedlicher Implementierung überladen werden.
Data Abstraction - Jede Darstellung von Daten, in denen die Implementierungsdetails verborgen (abstrahiert) sind.
Encapsulation - bezieht sich auf ein Konzept, bei dem alle Daten- und Elementfunktionen zu einem Objekt zusammengefasst werden.
Constructor - bezieht sich auf eine spezielle Art von Funktion, die automatisch aufgerufen wird, wenn eine Objektbildung aus einer Klasse vorliegt.
Destructor - bezieht sich auf eine spezielle Art von Funktion, die automatisch aufgerufen wird, wenn ein Objekt gelöscht wird oder den Gültigkeitsbereich verlässt.
PHP-Klassen definieren
Die allgemeine Form zum Definieren einer neuen Klasse in PHP lautet wie folgt:
<?php
class phpClass {
var $var1;
var $var2 = "constant string";
function myfunc ($arg1, $arg2) {
[..]
}
[..]
}
?>
Hier ist die Beschreibung jeder Zeile -
Die spezielle Form class, gefolgt vom Namen der Klasse, die Sie definieren möchten.
Eine Reihe von geschweiften Klammern, die eine beliebige Anzahl von Variablendeklarationen und Funktionsdefinitionen enthalten.
Variablendeklarationen beginnen mit dem Sonderformular var, gefolgt von einem herkömmlichen $ -Variablennamen; Sie können auch eine anfängliche Zuordnung zu einem konstanten Wert haben.
Funktionsdefinitionen ähneln eigenständigen PHP-Funktionen, sind jedoch lokal für die Klasse und werden zum Festlegen und Zugreifen auf Objektdaten verwendet.
Beispiel
Hier ist ein Beispiel, das eine Klasse von Büchertypen definiert -
<?php
class Books {
/* Member variables */
var $price;
var $title;
/* Member functions */
function setPrice($par){
$this->price = $par;
}
function getPrice(){
echo $this->price ."<br/>";
}
function setTitle($par){
$this->title = $par;
}
function getTitle(){
echo $this->title ." <br/>";
}
}
?>
Die Variable $thisist eine spezielle Variable und bezieht sich auf dasselbe Objekt, dh. selbst.
Objekte in PHP erstellen
Sobald Sie Ihre Klasse definiert haben, können Sie beliebig viele Objekte dieses Klassentyps erstellen. Im Folgenden finden Sie ein Beispiel für das Erstellen von Objekten mitnew Operator.
$physics = new Books;
$maths = new Books;
$chemistry = new Books;
Hier haben wir drei Objekte erstellt, und diese Objekte sind unabhängig voneinander und werden separat existieren. Als nächstes werden wir sehen, wie man auf Mitgliedsfunktionen zugreift und Mitgliedsvariablen verarbeitet.
Mitgliederfunktionen aufrufen
Nach dem Erstellen Ihrer Objekte können Sie Mitgliedsfunktionen aufrufen, die sich auf dieses Objekt beziehen. Eine Mitgliedsfunktion kann nur die Mitgliedsvariable des zugehörigen Objekts verarbeiten.
Das folgende Beispiel zeigt, wie Titel und Preise für die drei Bücher durch Aufrufen von Mitgliedsfunktionen festgelegt werden.
$physics->setTitle( "Physics for High School" );
$chemistry->setTitle( "Advanced Chemistry" );
$maths->setTitle( "Algebra" );
$physics->setPrice( 10 );
$chemistry->setPrice( 15 );
$maths->setPrice( 7 );
Jetzt rufen Sie andere Elementfunktionen auf, um die im obigen Beispiel festgelegten Werte abzurufen.
$physics->getTitle();
$chemistry->getTitle();
$maths->getTitle();
$physics->getPrice();
$chemistry->getPrice();
$maths->getPrice();
Dies führt zu folgendem Ergebnis:
Physics for High School
Advanced Chemistry
Algebra
10
15
7
Konstruktorfunktionen
Konstruktorfunktionen sind spezielle Arten von Funktionen, die automatisch aufgerufen werden, wenn ein Objekt erstellt wird. Wir nutzen dieses Verhalten also voll aus, indem wir viele Dinge durch Konstruktorfunktionen initialisieren.
PHP bietet eine spezielle Funktion namens __construct()einen Konstruktor definieren. Sie können beliebig viele Argumente an die Konstruktorfunktion übergeben.
Das folgende Beispiel erstellt einen Konstruktor für die Books-Klasse und initialisiert Preis und Titel für das Buch zum Zeitpunkt der Objekterstellung.
function __construct( $par1, $par2 ) {
$this->title = $par1;
$this->price = $par2;
}
Jetzt müssen wir die Set-Funktion nicht mehr separat aufrufen, um Preis und Titel festzulegen. Wir können diese beiden Elementvariablen nur zum Zeitpunkt der Objekterstellung initialisieren. Überprüfen Sie das folgende Beispiel unten -
$physics = new Books( "Physics for High School", 10 );
$maths = new Books ( "Advanced Chemistry", 15 );
$chemistry = new Books ("Algebra", 7 );
/* Get those set values */
$physics->getTitle();
$chemistry->getTitle();
$maths->getTitle();
$physics->getPrice();
$chemistry->getPrice();
$maths->getPrice();
Dies führt zu folgendem Ergebnis:
Physics for High School
Advanced Chemistry
Algebra
10
15
7
Zerstörer
Wie bei einer Konstruktorfunktion können Sie eine Destruktorfunktion mit function definieren __destruct(). Sie können alle Ressourcen in einem Destruktor freigeben.
Erbe
PHP-Klassendefinitionen können optional mithilfe der Extended-Klausel von einer übergeordneten Klassendefinition erben. Die Syntax lautet wie folgt:
class Child extends Parent {
<definition body>
}
Die Vererbung bewirkt, dass die untergeordnete Klasse (oder Unterklasse oder abgeleitete Klasse) die folgenden Merkmale aufweist:
Enthält automatisch alle Elementvariablendeklarationen der übergeordneten Klasse.
Hat automatisch alle gleichen Elementfunktionen wie das übergeordnete Element, was (standardmäßig) genauso funktioniert wie diese Funktionen im übergeordneten Element.
Das folgende Beispiel erbt die Books-Klasse und fügt je nach Anforderung weitere Funktionen hinzu.
class Novel extends Books {
var $publisher;
function setPublisher($par){
$this->publisher = $par;
}
function getPublisher(){
echo $this->publisher. "<br />";
}
}
Abgesehen von geerbten Funktionen behält die Klasse Novel nun zwei zusätzliche Elementfunktionen bei.
Funktionsüberschreibung
Funktionsdefinitionen in untergeordneten Klassen überschreiben gleichnamige Definitionen in übergeordneten Klassen. In einer untergeordneten Klasse können wir die Definition einer von der übergeordneten Klasse geerbten Funktion ändern.
Im folgenden Beispiel werden die Funktionen getPrice und getTitle überschrieben, um einige Werte zurückzugeben.
function getPrice() {
echo $this->price . "<br/>";
return $this->price;
}
function getTitle(){
echo $this->title . "<br/>";
return $this->title;
}
Öffentliche Mitglieder
Sofern Sie nichts anderes angeben, sind Eigenschaften und Methoden einer Klasse öffentlich. Das heißt, auf sie kann in drei möglichen Situationen zugegriffen werden -
Von außerhalb der Klasse, in der es deklariert ist
Aus der Klasse heraus, in der es deklariert ist
Aus einer anderen Klasse heraus, die die Klasse implementiert, in der sie deklariert ist
Bisher haben wir alle Mitglieder als öffentliche Mitglieder gesehen. Wenn Sie die Zugänglichkeit der Mitglieder einer Klasse einschränken möchten, definieren Sie Klassenmitglieder alsprivate oder protected.
Private Mitglieder
Indem Sie ein Mitglied als privat festlegen, beschränken Sie seine Zugänglichkeit auf die Klasse, in der es deklariert ist. Auf das private Mitglied kann nicht von Klassen verwiesen werden, die die Klasse erben, in der es deklariert ist, und es kann nicht von außerhalb der Klasse zugegriffen werden.
Ein Klassenmitglied kann mithilfe von privat gemacht werden private Schlüsselwort vor dem Mitglied.
class MyClass {
private $car = "skoda";
$driver = "SRK";
function __construct($par) {
// Statements here run every time
// an instance of the class
// is created.
}
function myPublicFunction() {
return("I'm visible!");
}
private function myPrivateFunction() {
return("I'm not visible outside!");
}
}
Wenn die MyClass- Klasse mit extended von einer anderen Klasse geerbt wird, sind myPublicFunction () und $ driver sichtbar. Die erweiterte Klasse hat keine Kenntnis von oder Zugriff auf myPrivateFunction und $ car, da sie als privat deklariert sind.
Geschützte Mitglieder
Auf eine geschützte Eigenschaft oder Methode kann in der Klasse zugegriffen werden, in der sie deklariert ist, sowie in Klassen, die diese Klasse erweitern. Geschützte Mitglieder sind außerhalb dieser beiden Klassen nicht verfügbar. Ein Klassenmitglied kann durch Verwendung geschützt werdenprotected Schlüsselwort vor dem Mitglied.
Hier ist eine andere Version von MyClass -
class MyClass {
protected $car = "skoda";
$driver = "SRK";
function __construct($par) {
// Statements here run every time
// an instance of the class
// is created.
}
function myPublicFunction() {
return("I'm visible!");
}
protected function myPrivateFunction() {
return("I'm visible in child class!");
}
}
Schnittstellen
Schnittstellen werden definiert, um den Implementierern gemeinsame Funktionsnamen bereitzustellen. Verschiedene Implementierer können diese Schnittstellen entsprechend ihren Anforderungen implementieren. Man kann sagen, Schnittstellen sind Skelette, die von Entwicklern implementiert werden.
Ab PHP5 ist es möglich, eine Schnittstelle wie diese zu definieren -
interface Mail {
public function sendMail();
}
Wenn dann eine andere Klasse diese Schnittstelle wie folgt implementiert -
class Report implements Mail {
// sendMail() Definition goes here
}
Konstanten
Eine Konstante ähnelt insofern einer Variablen, als sie einen Wert enthält, ist jedoch eher eine Funktion, da eine Konstante unveränderlich ist. Sobald Sie eine Konstante deklarieren, ändert sich diese nicht mehr.
Das Deklarieren einer Konstante ist einfach, wie in dieser Version von MyClass -
class MyClass {
const requiredMargin = 1.7;
function __construct($incomingValue) {
// Statements here run every time
// an instance of the class
// is created.
}
}
In dieser Klasse ist requireMargin eine Konstante. Es wird mit dem Schlüsselwort const deklariert und kann unter keinen Umständen in etwas anderes als 1.7 geändert werden. Beachten Sie, dass der Name der Konstante kein führendes $ hat, wie dies bei Variablennamen der Fall ist.
Abstrakte Klassen
Eine abstrakte Klasse kann nicht instanziiert, sondern nur vererbt werden. Sie deklarieren eine abstrakte Klasse mit dem Schlüsselwortabstract, so -
Beim Erben von einer abstrakten Klasse müssen alle in der Klassendeklaration des Elternteils als abstrakt gekennzeichneten Methoden vom Kind definiert werden. Darüber hinaus müssen diese Methoden mit derselben Sichtbarkeit definiert werden.
abstract class MyAbstractClass {
abstract function myAbstractFunction() {
}
}
Beachten Sie, dass vor Funktionsdefinitionen innerhalb einer abstrakten Klasse auch das Schlüsselwort abstract stehen muss. Es ist nicht legal, abstrakte Funktionsdefinitionen in einer nicht abstrakten Klasse zu haben.
Statisches Schlüsselwort
Wenn Sie Klassenmitglieder oder Methoden als statisch deklarieren, können Sie auf sie zugreifen, ohne dass eine Instanziierung der Klasse erforderlich ist. Auf ein als statisch deklariertes Mitglied kann nicht mit einem instanziierten Klassenobjekt zugegriffen werden (obwohl dies mit einer statischen Methode möglich ist).
Probieren Sie folgendes Beispiel aus -
<?php
class Foo {
public static $my_static = 'foo';
public function staticValue() {
return self::$my_static;
}
}
print Foo::$my_static . "\n";
$foo = new Foo();
print $foo->staticValue() . "\n";
?>
Endgültiges Schlüsselwort
PHP 5 führt das Schlüsselwort final ein, das verhindert, dass untergeordnete Klassen eine Methode überschreiben, indem der Definition final vorangestellt wird. Wenn die Klasse selbst endgültig definiert wird, kann sie nicht erweitert werden.
Das folgende Beispiel führt zu einem schwerwiegenden Fehler: Die endgültige Methode BaseClass :: moreTesting () kann nicht überschrieben werden.
<?php
class BaseClass {
public function test() {
echo "BaseClass::test() called<br>";
}
final public function moreTesting() {
echo "BaseClass::moreTesting() called<br>";
}
}
class ChildClass extends BaseClass {
public function moreTesting() {
echo "ChildClass::moreTesting() called<br>";
}
}
?>
Übergeordnete Konstruktoren aufrufen
Anstatt einen völlig neuen Konstruktor für die Unterklasse zu schreiben, schreiben wir ihn, indem wir den Konstruktor des übergeordneten Elements explizit aufrufen und dann alles tun, was zusätzlich zur Instanziierung der Unterklasse erforderlich ist. Hier ist ein einfaches Beispiel -
class Name {
var $_firstName;
var $_lastName;
function Name($first_name, $last_name) {
$this->_firstName = $first_name;
$this->_lastName = $last_name;
}
function toString() {
return($this->_lastName .", " .$this->_firstName);
}
}
class NameSub1 extends Name {
var $_middleInitial;
function NameSub1($first_name, $middle_initial, $last_name) {
Name::Name($first_name, $last_name);
$this->_middleInitial = $middle_initial;
}
function toString() {
return(Name::toString() . " " . $this->_middleInitial);
}
}
In diesem Beispiel haben wir eine übergeordnete Klasse (Name) mit einem Konstruktor mit zwei Argumenten und eine Unterklasse (NameSub1) mit einem Konstruktor mit drei Argumenten. Der Konstruktor von NameSub1 funktioniert, indem er seinen übergeordneten Konstruktor explizit mit der :: -Syntax aufruft (zwei seiner Argumente weitergibt) und dann ein zusätzliches Feld festlegt. In ähnlicher Weise definiert NameSub1 seine Nichtkonstruktor-toString () -Funktion in Bezug auf die übergeordnete Funktion, die es überschreibt.
NOTE- Ein Konstruktor kann mit demselben Namen wie der Name einer Klasse definiert werden. Es ist im obigen Beispiel definiert.