PHP'de Nesne Tabanlı Programlama

Evrenimizi güneş, dünya, ay vb. Gibi farklı nesnelerden oluştuğunu hayal edebiliriz. Benzer şekilde arabamızı tekerlek, direksiyon, dişli vb. Gibi farklı nesnelerden yapılmış hayal edebiliriz. Aynı şekilde her şeyi bir nesne olarak varsayan nesne yönelimli programlama kavramları ve farklı nesneler kullanarak bir yazılım uygular.

Nesneye Yönelik Kavramlar

Ayrıntıya girmeden önce, Nesne Yönelimli Programlama ile ilgili önemli terimleri tanımlayalım.

  • Class- Bu, yerel işlevlerin yanı sıra yerel verileri içeren, programcı tanımlı bir veri türüdür. Bir sınıfı, aynı türden (veya sınıftan) nesnenin birçok örneğini yapmak için bir şablon olarak düşünebilirsiniz.

  • Object- Bir sınıf tarafından tanımlanan veri yapısının bağımsız bir örneği. Bir sınıfı bir kez tanımlarsınız ve ardından ona ait birçok nesne yaparsınız. Nesneler, örnek olarak da bilinir.

  • Member Variable- Bunlar bir sınıf içinde tanımlanan değişkenlerdir. Bu veriler, sınıfın dışında görünmez olacak ve üye işlevler aracılığıyla erişilebilir olacak. Bu değişkenler, bir nesne oluşturulduktan sonra nesnenin niteliği olarak adlandırılır.

  • Member function - Bunlar, bir sınıf içinde tanımlanan işlevlerdir ve nesne verilerine erişmek için kullanılır.

  • Inheritance- Bir sınıf, bir ana sınıfın mevcut işlevini miras alarak tanımlandığında, buna miras denir. Burada alt sınıf, bir üst sınıfın tüm veya birkaç üye işlevini ve değişkenini miras alır.

  • Parent class- Başka bir sınıftan miras alınan bir sınıf. Buna temel sınıf veya süper sınıf da denir.

  • Child Class- Başka bir sınıftan miras alan bir sınıf. Buna alt sınıf veya türetilmiş sınıf da denir.

  • Polymorphism- Bu, aynı işlevin farklı amaçlar için kullanılabileceği nesne yönelimli bir kavramdır. Örneğin işlev adı aynı kalacaktır ancak farklı sayıda argüman alır ve farklı görevler yapabilir.

  • Overloading- operatörlerin bir kısmının veya tamamının, argümanlarının türlerine bağlı olarak farklı uygulamalara sahip olduğu bir tür polimorfizm. Benzer şekilde, işlevler de farklı uygulamalarla aşırı yüklenebilir.

  • Data Abstraction - Uygulama ayrıntılarının gizlendiği (soyutlandığı) herhangi bir veri temsili.

  • Encapsulation - bir nesne oluşturmak için tüm verileri ve üye işlevlerini birlikte kapsüllediğimiz bir kavramı ifade eder.

  • Constructor - Bir sınıftan bir nesne oluşumu olduğunda otomatik olarak çağrılacak özel bir işlev türünü ifade eder.

  • Destructor - Bir nesne silindiğinde veya kapsam dışına çıktığında otomatik olarak çağrılacak özel bir işlev türünü ifade eder.

PHP Sınıflarını Tanımlama

PHP'de yeni bir sınıfı tanımlamanın genel biçimi aşağıdaki gibidir -

<?php
   class phpClass {
      var $var1;
      var $var2 = "constant string";
      
      function myfunc ($arg1, $arg2) {
         [..]
      }
      [..]
   }
?>

İşte her satırın açıklaması -

  • Özel form classve ardından tanımlamak istediğiniz sınıfın adı.

  • Herhangi bir sayıda değişken bildirimini ve işlev tanımını içeren bir küme parantezi.

  • Değişken bildirimler özel formla başlar var, ardından geleneksel bir $ değişken adı gelir; ayrıca sabit bir değere ilk atamaları olabilir.

  • İşlev tanımları, bağımsız PHP işlevlerine çok benzer, ancak sınıf için yereldir ve nesne verilerini ayarlamak ve bunlara erişmek için kullanılacaktır.

Misal

İşte bir Kitap türü sınıfını tanımlayan bir örnek:

<?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/>";
      }
   }
?>

Değişken $thisözel bir değişkendir ve aynı nesneye, yani. kendisi.

PHP'de Nesne Oluşturma

Sınıfınızı tanımladıktan sonra, o sınıf türünden istediğiniz kadar nesne oluşturabilirsiniz. Aşağıda, kullanarak nesnenin nasıl oluşturulacağına bir örnek verilmiştir.new Şebeke.

$physics = new Books;
$maths = new Books;
$chemistry = new Books;

Burada üç nesne yarattık ve bu nesneler birbirinden bağımsız ve ayrı ayrı var olacaklar. Daha sonra üye işlevine nasıl erişileceğini ve üye değişkenlerini nasıl işleyeceğimizi göreceğiz.

Üye İşlevlerini Arama

Nesnelerinizi oluşturduktan sonra, o nesneyle ilgili üye işlevleri çağırabileceksiniz. Bir üye fonksiyon sadece ilgili nesnenin üye değişkenini işleyebilecektir.

Aşağıdaki örnek, üye işlevlerini arayarak üç kitap için başlık ve fiyatların nasıl ayarlanacağını gösterir.

$physics->setTitle( "Physics for High School" );
$chemistry->setTitle( "Advanced Chemistry" );
$maths->setTitle( "Algebra" );

$physics->setPrice( 10 );
$chemistry->setPrice( 15 );
$maths->setPrice( 7 );

Şimdi yukarıdaki örnekte ayarlanan değerleri almak için başka bir üye işlevi çağırıyorsunuz -

$physics->getTitle();
$chemistry->getTitle();
$maths->getTitle();
$physics->getPrice();
$chemistry->getPrice();
$maths->getPrice();

Bu, aşağıdaki sonucu verecektir -

Physics for High School
Advanced Chemistry
Algebra
10
15
7

Yapıcı İşlevleri

Yapıcı İşlevler, bir nesne oluşturulduğunda otomatik olarak çağrılan özel tür işlevlerdir. Bu nedenle, birçok şeyi yapıcı işlevler aracılığıyla başlatarak bu davranıştan tam olarak yararlanırız.

PHP adında özel bir işlev sağlar __construct()bir yapıcı tanımlamak için. Yapıcı işlevine istediğiniz kadar argüman aktarabilirsiniz.

Aşağıdaki örnek, Kitaplar sınıfı için bir kurucu oluşturacak ve nesne oluşturma sırasında kitabın fiyatını ve başlığını başlatacaktır.

function __construct( $par1, $par2 ) {
   $this->title = $par1;
   $this->price = $par2;
}

Şimdi fiyatı ve başlığı ayarlamak için set işlevini ayrı ayrı çağırmamıza gerek yok. Bu iki üye değişkeni yalnızca nesne oluşturma sırasında başlatabiliriz. Aşağıdaki örneği kontrol edin -

$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();

Bu, aşağıdaki sonucu verecektir -

Physics for High School
  Advanced Chemistry
  Algebra
  10
  15
  7

Yıkıcı

Bir yapıcı işlevi gibi, işlevi kullanarak bir yıkıcı işlevi tanımlayabilirsiniz. __destruct(). Bir yıkıcı ile tüm kaynakları serbest bırakabilirsiniz.

Miras

PHP sınıf tanımları isteğe bağlı olarak extends cümlesini kullanarak bir üst sınıf tanımından miras alabilir. Sözdizimi aşağıdaki gibidir -

class Child extends Parent {
   <definition body>
}

Kalıtımın etkisi, alt sınıfın (veya alt sınıfın veya türetilmiş sınıfın) aşağıdaki özelliklere sahip olmasıdır:

  • Üst sınıfın tüm üye değişken bildirimlerine otomatik olarak sahiptir.

  • Üst öğe ile otomatik olarak tüm aynı üye işlevlerine sahiptir ve bu (varsayılan olarak) üst öğede bu işlevlerle aynı şekilde çalışır.

Aşağıdaki örnek Books sınıfını devralır ve gereksinime göre daha fazla işlevsellik ekler.

class Novel extends Books {
   var $publisher;
   
   function setPublisher($par){
      $this->publisher = $par;
   }
   
   function getPublisher(){
      echo $this->publisher. "<br />";
   }
}

Artık, miras alınan işlevlerden ayrı olarak, Novel sınıfı iki ek üye işlevi tutar.

İşlev Geçersiz Kılma

Alt sınıflardaki işlev tanımları, üst sınıflarda aynı ada sahip tanımları geçersiz kılar. Bir çocuk sınıfta, ana sınıftan miras alınan bir fonksiyonun tanımını değiştirebiliriz.

Aşağıdaki örnekte getPrice ve getTitle işlevleri, bazı değerleri döndürmek için geçersiz kılınır.

function getPrice() {
   echo $this->price . "<br/>";
   return $this->price;
}
   
function getTitle(){
   echo $this->title . "<br/>";
   return $this->title;
}

Herkese Açık Üyeler

Siz aksini belirtmediğiniz sürece, bir sınıfın özellikleri ve yöntemleri herkese açıktır. Yani, üç olası durumda bunlara erişilebilir -

  • İlan edildiği sınıfın dışından

  • İlan edildiği sınıfın içinden

  • Bildirildiği sınıfı uygulayan başka bir sınıfın içinden

Şimdiye kadar tüm üyeleri halka açık üye olarak gördük. Bir sınıfın üyelerinin erişilebilirliğini sınırlamak isterseniz, sınıf üyelerini şu şekilde tanımlarsınız:private veya protected.

Özel üyeler

Bir üyeyi özel olarak belirleyerek, erişilebilirliğini bildirildiği sınıfla sınırlamış olursunuz. Özel üyeye, bildirildiği sınıfı miras alan sınıflardan başvurulamaz ve sınıf dışından erişilemez.

Bir sınıf üyesi kullanılarak gizli hale getirilebilir private üyenin önünde anahtar kelime.

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!");
   }
}

Tüm sınıfla sınıfı kullanılarak, başka bir sınıf ile uzanır kalıtsal sürücüyü, $ gibi, myPublicFunction () görünür olacaktır. Genişleyen sınıf, özel olarak ilan edildikleri için myPrivateFunction ve $ car hakkında herhangi bir farkındalığa veya bunlara erişime sahip olmayacak.

Korumalı üyeler

Korumalı bir özellik veya yönteme, bildirildiği sınıfta ve bu sınıfı genişleten sınıflarda erişilebilir. Korumalı üyeler bu iki tür sınıfın dışında mevcut değildir. Bir sınıf üyesi kullanılarak korunabilir hale getirilebilirprotected Üyenin önünde anahtar kelime.

İşte MyClass'ın farklı bir versiyonu -

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!");
   }
}

Arayüzler

Arayüzler, uygulayıcılara ortak bir işlev adı sağlamak için tanımlanır. Farklı uygulayıcılar bu arayüzleri gereksinimlerine göre uygulayabilir. Arayüzler, geliştiriciler tarafından uygulanan iskeletlerdir diyebilirsiniz.

PHP5'ten itibaren, bunun gibi bir arayüz tanımlamak mümkündür -

interface Mail {
   public function sendMail();
}

Ardından, başka bir sınıf bu arabirimi böyle uygularsa,

class Report implements Mail {
   // sendMail() Definition goes here
}

Sabitler

Bir sabit, bir değeri tutması açısından bir değişken gibidir, ancak daha çok bir işleve benzer çünkü sabit, değişmezdir. Bir sabit belirlediğinizde değişmez.

MyClass'ın bu sürümünde yapıldığı gibi, bir sabit tanımlamak kolaydır -

class MyClass {
   const requiredMargin = 1.7;
   
   function __construct($incomingValue) {
      // Statements here run every time
      // an instance of the class
      // is created.
   }
}

Bu sınıfta, requiredMargin bir sabittir. Const anahtar sözcüğü ile bildirilir ve hiçbir koşulda 1.7'den başka bir şeye değiştirilemez. Değişken adlarında olduğu gibi sabitin adının başında bir $ olmadığına dikkat edin.

Soyut Sınıflar

Soyut bir sınıf, somutlaştırılamayan, yalnızca miras alınan bir sınıftır. Anahtar kelimeyle soyut bir sınıf bildirirsinizabstract, bunun gibi -

Soyut bir sınıftan miras alırken, ebeveynin sınıf bildiriminde soyut olarak işaretlenmiş tüm yöntemler çocuk tarafından tanımlanmalıdır; ayrıca bu yöntemler aynı görünürlükle tanımlanmalıdır.

abstract class MyAbstractClass {
   abstract function myAbstractFunction() {
   }
}

Soyut bir sınıftaki işlev tanımlarından önce abstract anahtar sözcüğü gelmelidir. Soyut olmayan bir sınıf içinde soyut fonksiyon tanımlarına sahip olmak yasal değildir.

Statik Anahtar Kelime

Sınıf üyelerini veya yöntemleri statik olarak bildirmek, onları sınıfın somutlaştırılmasına gerek kalmadan erişilebilir kılar. Statik olarak bildirilen bir üyeye, başlatılmış bir sınıf nesnesiyle erişilemez (ancak statik bir yöntem olabilir).

Aşağıdaki örneği deneyin -

<?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";
?>

Son Anahtar Kelime

PHP 5, tanımın önüne final koyarak çocuk sınıfların bir yöntemi geçersiz kılmasını önleyen son anahtar kelimeyi sunar. Sınıfın kendisi nihai olarak tanımlanıyorsa, uzatılamaz.

Aşağıdaki örnek, Ölümcül hataya neden olur: Nihai yöntem BaseClass :: moreTesting () geçersiz kılınamaz

<?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>";
      }
   }
?>

Üst kuruculara çağrı

Alt sınıf için tamamen yeni bir kurucu yazmak yerine, onu ebeveynin kurucusunu açıkça çağırarak ve sonra alt sınıfın somutlaştırılmasına ek olarak gerekli olanı yaparak yazalım. İşte basit bir örnek -

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);
   }
}

Bu örnekte, iki bağımsız değişkenli bir ana sınıfımız (Ad) ve üç bağımsız değişkenli bir alt sınıfımız (NameSub1) var. NameSub1'in yapıcısı, ana yapıcısını :: sözdizimini kullanarak açıkça çağırarak (argümanlarından ikisini birlikte geçirerek) ve sonra ek bir alan ayarlayarak işlev görür. Benzer şekilde, NameSub1, yapıcı olmayan toString () işlevini geçersiz kıldığı üst işlev açısından tanımlar.

NOTE- Bir kurucu, bir sınıfın adıyla aynı adla tanımlanabilir. Yukarıdaki örnekte tanımlanmıştır.