हम इस ट्यूटोरियल में सीखने वाले है कि जावा पॉलीमॉरफिस्म (Java Polymorphism in Hindi) और हम इसे कैसे इस्तमाल कर सकते हैं? polymorphism एक वस्तु की कई रूप धारण करने की क्षमता है। OOP में polymorphism का सबसे आम उपयोग तब होता है जब चाइल्ड क्लास ऑब्जेक्ट को संदर्भित करने के लिए पैरेंट क्लास रेफरेंस का उपयोग किया जाता है।
कोई भी जावा ऑब्जेक्ट जो एक से अधिक IS-A परीक्षण pass कर सकता है, उसे बहुरूपी माना जाता है। जावा में सभी जावा ऑब्जेक्ट बहुरूपी होते हैं क्योंकि कोई भी ऑब्जेक्ट अपने प्रकार के लिए और क्लास ऑब्जेक्ट के लिए IS-A टेस्ट pass करेगा।
Table of Contents
यह जानना महत्वपूर्ण है कि किसी वस्तु तक पहुँचने का एकमात्र संभव तरीका एक संदर्भ चर के माध्यम से है। एक संदर्भ चर केवल एक प्रकार का हो सकता है। एक बार घोषित होने के बाद, संदर्भ चर के प्रकार को बदला नहीं जा सकता।
संदर्भ चर को अन्य वस्तुओं के लिए पुन: असाइन किया जा सकता है बशर्ते कि इसे अंतिम घोषित नहीं किया गया हो। संदर्भ चर का प्रकार उन विधियों को निर्धारित करेगा जिन्हें वह वस्तु पर लागू कर सकता है।
एक संदर्भ चर अपने घोषित प्रकार के किसी भी वस्तु या उसके घोषित प्रकार के किसी भी उपप्रकार को संदर्भित कर सकता है। एक संदर्भ चर को वर्ग या इंटरफ़ेस प्रकार के रूप में घोषित किया जा सकता है।
उदाहरण
आइए एक उदाहरण देखें।
public interface Vegetarian{}
public class Animal{}
public class Deer extends Animal implements Vegetarian{}
अब, हिरण वर्ग को बहुरूपी माना जाता है क्योंकि इसमें कई वंशानुक्रम हैं। उपरोक्त उदाहरणों के लिए निम्नलिखित सत्य हैं –
- A Deer IS-A Animal
- A Deer IS-A Vegetarian
- A Deer IS-A Deer
- A Deer IS-A Object
जब हम संदर्भ चर तथ्यों को हिरण वस्तु के संदर्भ में लागू करते हैं, तो निम्नलिखित घोषणाएँ कानूनी हैं –
Example
Deer d = new Deer();
Animal a = d;
Vegetarian v = d;
Object o = d;
सभी संदर्भ चर d, a, v, o ढेर में एक ही हिरण वस्तु को संदर्भित करते हैं।
वर्चुअल मेथड्स (Virtual Methods in Hindi)
इस खंड में, मैं आपको दिखाऊंगा कि कैसे जावा में ओवरराइड विधियों का व्यवहार आपको अपनी कक्षाओं को डिजाइन करते समय polymorphism का लाभ उठाने की अनुमति देता है।
हमने पहले ही मेथड ओवरराइडिंग पर चर्चा की है, जहाँ एक चाइल्ड क्लास अपने पैरेंट में एक मेथड को ओवरराइड कर सकता है। एक ओवरराइड विधि अनिवार्य रूप से मूल वर्ग में छिपी हुई है और जब तक कि बाल वर्ग ओवरराइडिंग विधि के भीतर सुपर कीवर्ड का उपयोग नहीं करता तब तक इसका आह्वान नहीं किया जाता है।
Example
/* फ़ाइल का नाम : Employee.java */
public class Employee {
private String name;
private String address;
private int number;
public Employee(String name, String address, int number) {
System.out.println(“Constructing an Employee”);
this.name = name;
this.address = address;
this.number = number;
}
public void mailCheck() {
System.out.println(“Mailing a check to ” + this.name + ” ” + this.address);
}
public String toString() {
return name + ” ” + address + ” ” + number;
}
public String getName() {
return name;
}
public String getAddress() {
return address;
}
public void setAddress(String newAddress) {
address = newAddress;
}
public int getNumber() {
return number;
}
}
अब मान लीजिए कि हम Employee वर्ग का विस्तार इस प्रकार करते हैं –
/* फ़ाइल का नाम : Salary.java */
public class Salary extends Employee {
private double salary; // वार्षिक वेतन
public Salary(String name, String address, int number, double salary) {
super(name, address, number);
setSalary(salary);
}
public void mailCheck() {
System.out.println(“Within mailCheck of Salary class “);
System.out.println(“Mailing check to ” + getName()
+ ” with salary ” + salary);
}
public double getSalary() {
return salary;
}
public void setSalary(double newSalary) {
if(newSalary >= 0.0) {
salary = newSalary;
}
}
public double computePay() {
System.out.println(“Computing salary pay for ” + getName());
return salary/52;
}
}
अब, आप निम्नलिखित प्रोग्राम का ध्यानपूर्वक अध्ययन करें और इसके आउटपुट को निर्धारित करने का प्रयास करें –
/* फ़ाइल का नाम : VirtualDemo.java */
public class VirtualDemo {
public static void main(String [] args) {
Salary s = new Salary(“Mohd Mohtashim”, “Ambehta, UP”, 3, 3600.00);
Employee e = new Salary(“John Adams”, “Boston, MA”, 2, 2400.00);
System.out.println(“Call mailCheck using Salary reference –“);
s.mailCheck();
System.out.println(“\n Call mailCheck using Employee reference–“);
e.mailCheck();
}
}
यह निम्नलिखित परिणाम देगा –
Output
Constructing an Employee
Constructing an Employee
Call mailCheck using Salary reference —
Within mailCheck of Salary class
Mailing check to Mohd Mohtashim with salary 3600.0
Call mailCheck using Employee reference–
Within mailCheck of Salary class
Mailing check to John Adams with salary 2400.0
यहां, हम दो सैलरी ऑब्जेक्ट्स को इन्स्तांत करते हैं। एक वेतन संदर्भ का उपयोग कर रहा है, और दूसरा Employee संदर्भ ई का उपयोग कर रहा है।
s.mailCheck() को इनवोक करते समय, कंपाइलर मेलचेक() को सैलरी क्लास में कंपाइल टाइम पर देखता है, और JVM रन टाइम पर सैलरी क्लास में mailCheck() को इनवॉइस करता है।
ई पर मेलचेक() काफी अलग है क्योंकि ई एक Employee संदर्भ है। जब कंपाइलर e.mailCheck() देखता है, तो कंपाइलर Employee वर्ग में mailCheck() विधि देखता है।
यहाँ, संकलन के समय, कंपाइलर ने इस कथन को मान्य करने के लिए Employee में mailCheck() का उपयोग किया। हालाँकि, रनटाइम पर, JVM वेतन वर्ग में mailCheck () को आमंत्रित करता है।
इस व्यवहार को वर्चुअल मेथड इनवोकेशन कहा जाता है, और इन मेथड्स को वर्चुअल मेथड्स कहा जाता है। रन टाइम पर एक ओवरराइड विधि लागू की जाती है, इससे कोई फर्क नहीं पड़ता कि संदर्भ किस प्रकार का डेटा है जिसका उपयोग संकलन समय पर स्रोत कोड में किया गया था।
हम उम्मीद करते है कि आपको “जावा पॉलीमॉरफिस्म (Java Polymorphism in Hindi)” से सम्बंधित जानकारी हिंदी में समझ में आयी होंगी यदि आपको बताई गई जानकारी अच्छी लगी हो तो अपने दोस्तों में ऐसे शेयर करे जिससे उनकी भी हेल्प हो सके धन्यवाद!