PHP में ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग
हम अपने ब्रह्माण्ड की कल्पना विभिन्न वस्तुओं जैसे सूरज, पृथ्वी, चंद्रमा आदि से कर सकते हैं। इसी तरह हम अपनी कार की कल्पना विभिन्न वस्तुओं जैसे पहिया, स्टीयरिंग, गियर आदि से कर सकते हैं। उसी तरह से ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग अवधारणाएं हैं जो एक वस्तु के रूप में सब कुछ मानती हैं विभिन्न वस्तुओं का उपयोग करके एक सॉफ्टवेयर लागू करें।
ऑब्जेक्ट ओरिएंटेड कॉन्सेप्ट्स
इससे पहले कि हम विस्तार से जाएं, ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग से संबंधित महत्वपूर्ण शब्दों को परिभाषित करते हैं।
Class- यह एक प्रोग्रामर-परिभाषित डेटा प्रकार है, जिसमें स्थानीय कार्यों के साथ-साथ स्थानीय डेटा भी शामिल है। आप वस्तु के एक ही प्रकार (या वर्ग) के कई उदाहरण बनाने के लिए एक वर्ग के रूप में एक वर्ग के बारे में सोच सकते हैं।
Object- एक वर्ग द्वारा परिभाषित डेटा संरचना का एक व्यक्तिगत उदाहरण। आप एक बार एक वर्ग को परिभाषित करते हैं और फिर कई ऑब्जेक्ट बनाते हैं जो इसके अंतर्गत आते हैं। वस्तुओं को उदाहरण के रूप में भी जाना जाता है।
Member Variable- ये एक वर्ग के अंदर परिभाषित चर हैं। यह डेटा कक्षा के बाहर अदृश्य होगा और सदस्य कार्यों के माध्यम से पहुँचा जा सकता है। किसी वस्तु के बनने के बाद इन चर को वस्तु का गुण कहा जाता है।
Member function - ये एक वर्ग के अंदर परिभाषित फ़ंक्शन हैं और इसका उपयोग ऑब्जेक्ट डेटा तक पहुंचने के लिए किया जाता है।
Inheritance- जब किसी वर्ग को किसी मूल वर्ग के मौजूदा फलन को परिभाषित करके परिभाषित किया जाता है तो उसे वंशानुक्रम कहा जाता है। यहां चाइल्ड क्लास एक पेरेंट क्लास के सभी या कुछ सदस्य कार्यों और चर का वारिस करेगी।
Parent class- एक वर्ग जो दूसरे वर्ग से विरासत में मिला है। इसे बेस क्लास या सुपर क्लास भी कहा जाता है।
Child Class- एक वर्ग जो दूसरे वर्ग से विरासत में मिला है। इसे उपवर्ग या व्युत्पन्न वर्ग भी कहा जाता है।
Polymorphism- यह एक ऑब्जेक्ट ओरिएंटेड कॉन्सेप्ट है जहां एक ही फ़ंक्शन को विभिन्न उद्देश्यों के लिए उपयोग किया जा सकता है। उदाहरण के लिए, फ़ंक्शन का नाम एक ही रहेगा लेकिन यह विभिन्न प्रकार के तर्क देता है और अलग कार्य कर सकता है।
Overloading- एक प्रकार का बहुरूपता जिसमें कुछ या सभी संचालकों के पास उनके तर्कों के प्रकारों के आधार पर अलग-अलग कार्यान्वयन होते हैं। इसी तरह कार्यों को भी अलग-अलग कार्यान्वयन के साथ ओवरलोड किया जा सकता है।
Data Abstraction - डेटा का कोई प्रतिनिधित्व जिसमें कार्यान्वयन विवरण छिपा हुआ है (सार)।
Encapsulation - एक अवधारणा को संदर्भित करता है जहां हम ऑब्जेक्ट बनाने के लिए सभी डेटा और सदस्य कार्यों को एक साथ संलग्न करते हैं।
Constructor - एक विशेष प्रकार के फ़ंक्शन को संदर्भित करता है जिसे जब भी किसी वर्ग से ऑब्जेक्ट फॉर्मेशन कहा जाता है, स्वचालित रूप से कहा जाएगा।
Destructor - एक विशेष प्रकार के फ़ंक्शन को संदर्भित करता है जिसे जब भी कोई ऑब्जेक्ट हटा दिया जाता है या गुंजाइश से बाहर हो जाता है, तो स्वचालित रूप से कॉल किया जाएगा।
PHP कक्षाएं परिभाषित करना
PHP में एक नए वर्ग को परिभाषित करने के लिए सामान्य रूप निम्नानुसार है -
<?php
class phpClass {
var $var1;
var $var2 = "constant string";
function myfunc ($arg1, $arg2) {
[..]
}
[..]
}
?>
यहाँ प्रत्येक पंक्ति का वर्णन है -
विशेष रूप class, उस वर्ग के नाम से जिसे आप परिभाषित करना चाहते हैं।
चर घोषणाओं और फ़ंक्शन परिभाषाओं की किसी भी संख्या को संलग्न करते हुए ब्रेसिज़ का एक सेट।
परिवर्तनीय घोषणाएं विशेष रूप से शुरू होती हैं var, जो एक पारंपरिक $ चर नाम के बाद है; उनके पास एक स्थिर मान के लिए एक प्रारंभिक असाइनमेंट भी हो सकता है।
फ़ंक्शन परिभाषाएँ बहुत हद तक स्टैंडअलोन PHP फ़ंक्शन की तरह दिखती हैं, लेकिन कक्षा के लिए स्थानीय हैं और इसका उपयोग ऑब्जेक्ट डेटा सेट और एक्सेस करने के लिए किया जाएगा।
उदाहरण
यहाँ एक उदाहरण है जो पुस्तकों के प्रकार को परिभाषित करता है -
<?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/>";
}
}
?>
चर $thisएक विशेष चर है और यह उसी वस्तु को संदर्भित करता है। अपने आप।
PHP में ऑब्जेक्ट बनाना
एक बार जब आप अपनी कक्षा को परिभाषित कर लेते हैं, तो आप उस वर्ग के प्रकार की जितनी चाहें उतनी वस्तुएँ बना सकते हैं। निम्नलिखित का उपयोग कैसे वस्तु बनाने के लिए का एक उदाहरण हैnew ऑपरेटर।
$physics = new Books;
$maths = new Books;
$chemistry = new Books;
यहां हमने तीन ऑब्जेक्ट बनाए हैं और ये ऑब्जेक्ट एक-दूसरे से स्वतंत्र हैं और उनका अस्तित्व अलग-अलग होगा। आगे हम देखेंगे कि सदस्य फ़ंक्शन और प्रक्रिया सदस्य चर का उपयोग कैसे करें।
कॉलिंग सदस्य कार्य
अपनी वस्तुओं को बनाने के बाद, आप उस ऑब्जेक्ट से संबंधित सदस्य कार्यों को कॉल करने में सक्षम होंगे। एक सदस्य समारोह केवल संबंधित वस्तु के सदस्य चर को संसाधित करने में सक्षम होगा।
निम्नलिखित उदाहरण से पता चलता है कि सदस्य कार्यों को कॉल करके तीन पुस्तकों के लिए शीर्षक और कीमतें कैसे सेट करें।
$physics->setTitle( "Physics for High School" );
$chemistry->setTitle( "Advanced Chemistry" );
$maths->setTitle( "Algebra" );
$physics->setPrice( 10 );
$chemistry->setPrice( 15 );
$maths->setPrice( 7 );
अब आप उपरोक्त उदाहरण में दिए गए मानों को प्राप्त करने के लिए अन्य सदस्य कार्यों को कहते हैं -
$physics->getTitle();
$chemistry->getTitle();
$maths->getTitle();
$physics->getPrice();
$chemistry->getPrice();
$maths->getPrice();
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Physics for High School
Advanced Chemistry
Algebra
10
15
7
कंस्ट्रक्टर के कार्य
कन्स्ट्रक्टर फ़ंक्शंस एक विशेष प्रकार के फ़ंक्शंस हैं जो किसी ऑब्जेक्ट के बनने पर स्वचालित रूप से कहलाते हैं। इसलिए हम इस कार्य का पूरा लाभ उठाते हैं, कई कार्यों को आरम्भिक कार्यों के द्वारा।
PHP एक विशेष फ़ंक्शन प्रदान करता है जिसे कहा जाता है __construct()एक कंस्ट्रक्टर को परिभाषित करने के लिए। कंस्ट्रक्टर फंक्शन में आप जितने चाहें उतने तर्क पारित कर सकते हैं।
उदाहरण के बाद, बुक्स क्लास के लिए एक कंस्ट्रक्टर बनाएगा और यह ऑब्जेक्ट निर्माण के समय पुस्तक के लिए मूल्य और शीर्षक को इनिशियलाइज़ करेगा।
function __construct( $par1, $par2 ) {
$this->title = $par1;
$this->price = $par2;
}
अब हमें प्राइस और टाइटल सेट करने के लिए अलग से फंक्शन सेट करने की जरूरत नहीं है। हम केवल ऑब्जेक्ट निर्माण के समय इन दो सदस्य चर को इनिशियलाइज़ कर सकते हैं। नीचे दिए गए उदाहरण की जाँच करें -
$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();
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Physics for High School
Advanced Chemistry
Algebra
10
15
7
नाशक
एक कंस्ट्रक्टर फ़ंक्शन की तरह आप फ़ंक्शन का उपयोग करके एक विध्वंसक फ़ंक्शन को परिभाषित कर सकते हैं __destruct()। आप एक विध्वंसक में सभी संसाधनों को जारी कर सकते हैं।
विरासत
PHP वर्ग परिभाषाएँ वैकल्पिक रूप से मूल खंड परिभाषा से वंशानुक्रम का उपयोग करके प्राप्त कर सकती हैं। वाक्य विन्यास इस प्रकार है -
class Child extends Parent {
<definition body>
}
वंशानुक्रम का प्रभाव यह है कि बाल वर्ग (या उपवर्ग या व्युत्पन्न वर्ग) की निम्नलिखित विशेषताएं हैं -
मूल कक्षा के सभी सदस्य चर घोषणाओं को स्वचालित रूप से किया जाता है।
माता-पिता के रूप में स्वचालित रूप से सभी सदस्य कार्य होते हैं, जो (डिफ़ॉल्ट रूप से) उसी तरह काम करेंगे जैसे कि वे कार्य माता-पिता में करते हैं।
उदाहरण के बाद, पुस्तकों की श्रेणी विरासत में मिलती है और आवश्यकता के आधार पर अधिक कार्यक्षमता जोड़ता है।
class Novel extends Books {
var $publisher;
function setPublisher($par){
$this->publisher = $par;
}
function getPublisher(){
echo $this->publisher. "<br />";
}
}
अब विरासत में मिले कार्यों के अलावा, क्लास नोवेल दो अतिरिक्त सदस्य कार्य करता है।
ओवरराइडिंग
चाइल्ड क्लासेस में फंक्शन की परिभाषाएँ पैरेंट क्लासेस में समान नाम वाली परिभाषाओं को ओवरराइड करती हैं। एक बच्चे की कक्षा में, हम मूल वर्ग से विरासत में मिली फ़ंक्शन की परिभाषा को संशोधित कर सकते हैं।
निम्न उदाहरण में getPrice और getTitle फ़ंक्शन को कुछ मानों को वापस करने के लिए ओवरराइड किया जाता है।
function getPrice() {
echo $this->price . "<br/>";
return $this->price;
}
function getTitle(){
echo $this->title . "<br/>";
return $this->title;
}
सार्वजनिक सदस्य
जब तक आप अन्यथा निर्दिष्ट नहीं करते हैं, तब तक किसी वर्ग के गुण और तरीके सार्वजनिक हैं। यह कहना है, वे तीन संभावित स्थितियों में पहुँचा जा सकता है -
उस वर्ग के बाहर से जिसमें यह घोषित किया गया है
उस वर्ग के भीतर से जिसमें यह घोषित किया गया है
किसी अन्य वर्ग के भीतर से वह उस वर्ग को लागू करता है जिसमें वह घोषित किया गया है
अब तक हमने सभी सदस्यों को सार्वजनिक सदस्यों के रूप में देखा है। यदि आप किसी वर्ग के सदस्यों की पहुंच को सीमित करना चाहते हैं तो आप वर्ग के सदस्यों को परिभाषित करते हैंprivate या protected।
निजी सदस्य
एक सदस्य को निजी रूप से नामित करके, आप उसकी पहुँच को उस वर्ग तक सीमित कर देते हैं जिसमें वह घोषित किया जाता है। निजी सदस्य को उन वर्गों से संदर्भित नहीं किया जा सकता है जो उस वर्ग को विरासत में देते हैं जिसमें यह घोषित किया गया है और इसे कक्षा के बाहर से एक्सेस नहीं किया जा सकता है।
एक वर्ग के सदस्य का उपयोग करके निजी बनाया जा सकता है private सदस्य का कीवर्ड उल्लंघन।
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!");
}
}
जब MyClass क्लास को एक्सटेंड्स का उपयोग करके अन्य वर्ग द्वारा विरासत में मिला है, तो myPublicFunction () दिखाई देगा, जैसा कि $ ड्राइवर होगा। विस्तारित वर्ग को myPStreetFunction और $ कार के बारे में कोई जागरूकता नहीं होगी, क्योंकि वे निजी घोषित किए जाते हैं।
रक्षित सदस्य
एक संरक्षित संपत्ति या विधि उस वर्ग में सुलभ है जिसमें यह घोषित किया गया है, साथ ही साथ उन कक्षाओं में जो उस वर्ग का विस्तार करते हैं। उन दो प्रकार के वर्गों के बाहर संरक्षित सदस्य उपलब्ध नहीं हैं। एक वर्ग के सदस्य का उपयोग करके संरक्षित किया जा सकता हैprotected सदस्य के सामने कीवर्ड।
यहाँ 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!");
}
}
इंटरफेस
कार्यान्वयनकर्ताओं को एक सामान्य फ़ंक्शन नाम प्रदान करने के लिए इंटरफेस को परिभाषित किया गया है। विभिन्न कार्यान्वयनकर्ता अपनी आवश्यकताओं के अनुसार उन इंटरफेस को लागू कर सकते हैं। आप कह सकते हैं, इंटरफेस कंकाल हैं जो डेवलपर्स द्वारा कार्यान्वित किए जाते हैं।
PHP5 के रूप में, इस तरह से एक इंटरफ़ेस को परिभाषित करना संभव है -
interface Mail {
public function sendMail();
}
फिर, यदि कोई अन्य वर्ग उस इंटरफ़ेस को लागू करता है, जैसे -
class Report implements Mail {
// sendMail() Definition goes here
}
स्थिरांक
एक स्थिरांक एक चर की तरह कुछ है, इसमें वह एक मूल्य रखता है, लेकिन वास्तव में एक फ़ंक्शन की तरह अधिक है क्योंकि एक स्थिर अपरिवर्तनीय है। एक बार जब आप एक निरंतर की घोषणा करते हैं, तो यह नहीं बदलता है।
एक निरंतर की घोषणा करना आसान है, जैसा कि MyClass के इस संस्करण में किया गया है -
class MyClass {
const requiredMargin = 1.7;
function __construct($incomingValue) {
// Statements here run every time
// an instance of the class
// is created.
}
}
इस वर्ग में, आवश्यक मॉर्गिन एक स्थिर है। इसे कीवर्ड कॉस्ट के साथ घोषित किया जाता है, और किसी भी परिस्थिति में इसे 1.7 के अलावा किसी भी चीज़ में नहीं बदला जा सकता है। ध्यान दें कि स्थिर नाम में अग्रणी $ नहीं है, जैसा कि चर नाम करते हैं।
सार वर्ग
एक अमूर्त वर्ग वह है जिसे तात्कालिक नहीं किया जा सकता है, केवल विरासत में मिला है। आप कीवर्ड के साथ एक अमूर्त वर्ग घोषित करते हैंabstract, इस तरह से -
जब एक अमूर्त वर्ग से विरासत में मिला, तो माता-पिता की कक्षा की घोषणा में सार के सभी तरीकों को बच्चे द्वारा परिभाषित किया जाना चाहिए; इसके अलावा, इन तरीकों को समान दृश्यता के साथ परिभाषित किया जाना चाहिए।
abstract class MyAbstractClass {
abstract function myAbstractFunction() {
}
}
ध्यान दें कि अमूर्त वर्ग के अंदर फ़ंक्शन परिभाषाएँ भी कीवर्ड सार से पहले होनी चाहिए। एक गैर-अमूर्त वर्ग के अंदर अमूर्त फ़ंक्शन परिभाषाएं होना कानूनी नहीं है।
स्थैतिक खोजशब्द
कक्षा के सदस्यों या विधियों को स्थैतिक घोषित करने से उन्हें कक्षा की तात्कालिकता की आवश्यकता के बिना सुलभ हो जाता है। स्थैतिक के रूप में घोषित सदस्य को तात्कालिक वर्ग वस्तु (हालांकि एक स्थैतिक विधि कर सकते हैं) के साथ पहुँचा नहीं जा सकता है।
निम्नलिखित उदाहरण देखें -
<?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";
?>
अंतिम खोजशब्द
PHP 5 अंतिम कीवर्ड का परिचय देता है, जो बाल कक्षाओं को अंतिम के साथ परिभाषा को उपसर्ग करके एक विधि को ओवरराइड करने से रोकता है। यदि वर्ग को ही अंतिम रूप से परिभाषित किया जा रहा है तो इसे बढ़ाया नहीं जा सकता है।
घातक परिणाम में निम्नलिखित उदाहरण परिणाम: अंतिम विधि को ओवरराइड नहीं कर सकता है
<?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>";
}
}
?>
अभिभावक निर्माणकर्ताओं को बुला रहे हैं
उपवर्ग के लिए एक पूरी तरह से नया कंस्ट्रक्टर लिखने के बजाय, इसे स्पष्ट रूप से माता-पिता के कंस्ट्रक्टर को लिखकर लिखें और फिर उपवर्ग के तात्कालिकता के अलावा जो कुछ भी आवश्यक हो उसे करें। यहाँ एक सरल उदाहरण है -
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);
}
}
इस उदाहरण में, हमारे पास एक पैरेंट क्लास (नाम) है, जिसमें दो-तर्क निर्माता और एक उपवर्ग (NameSub1) है, जिसमें तीन-तर्क निर्माता है। NameSub1 के निर्माता अपने मूल निर्माणकर्ता को स्पष्ट रूप से बुलाकर :: वाक्यविन्यास (इसके दो तर्क पास करके) का उपयोग करके और फिर एक अतिरिक्त फ़ील्ड सेट करके कार्य करता है। इसी प्रकार, NameSub1 अपने गैर कंस्ट्रक्टर को स्थिर () फ़ंक्शन को मूल फ़ंक्शन के संदर्भ में परिभाषित करता है जिसे वह ओवरराइड करता है।
NOTE- एक कंस्ट्रक्टर को उसी नाम से परिभाषित किया जा सकता है जैसे कि एक वर्ग का नाम। इसे उपरोक्त उदाहरण में परिभाषित किया गया है।