डी प्रोग्रामिंग - उपनाम
उपनाम, जैसा कि नाम से पता चलता है, मौजूदा नामों के लिए एक वैकल्पिक नाम प्रदान करता है। उपनाम के लिए वाक्यविन्यास नीचे दिखाया गया है।
alias new_name = existing_name;
निम्नलिखित पुराना सिंटैक्स है, यदि आप कुछ पुराने प्रारूप उदाहरणों को देखें। इसके उपयोग को हतोत्साहित किया जाता है।
alias existing_name new_name;
एक और वाक्यविन्यास भी है जो अभिव्यक्ति के साथ प्रयोग किया जाता है और यह नीचे दिया गया है जिसमें हम सीधे अभिव्यक्ति के बजाय उपनाम नाम का उपयोग कर सकते हैं।
alias expression alias_name ;
जैसा कि आप जानते हैं, एक टाइपडिफ नए प्रकार बनाने की क्षमता जोड़ता है। उपनाम अन्य प्रकार के और भी अधिक का काम कर सकते हैं। उपनाम का उपयोग करने के लिए एक सरल उदाहरण नीचे दिखाया गया है जो std.conv हेडर का उपयोग करता है जो टाइप रूपांतरण क्षमता प्रदान करता है।
import std.stdio;
import std.conv:to;
alias to!(string) toString;
void main() {
int a = 10;
string s = "Test"~toString(a);
writeln(s);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Test10
स्ट्रिंग (ए) का उपयोग करने के बजाय उपरोक्त उदाहरण में, हमने इसे उपनाम के लिए सौंपा और इसे समझने के लिए इसे और अधिक सुविधाजनक और सरल बना दिया।
ट्यूपल के लिए उपनाम
आइए एक और उदाहरण देखें, जहां हम एक ट्यूपल के लिए अन्य नाम निर्धारित कर सकते हैं।
import std.stdio;
import std.typetuple;
alias TypeTuple!(int, long) TL;
void method1(TL tl) {
writeln(tl[0],"\t", tl[1] );
}
void main() {
method1(5, 6L);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
5 6
उपरोक्त उदाहरण में, टाइप ट्यूल को उपनाम वेरिएबल को सौंपा गया है और यह विधि की परिभाषा और चर की पहुंच को सरल करता है। जब हम इस प्रकार के टुपल्स का पुन: उपयोग करने का प्रयास करते हैं तो इस तरह की पहुँच और भी उपयोगी होती है।
डेटा प्रकार के लिए उपनाम
कई बार, हम उन सामान्य डेटा प्रकारों को परिभाषित कर सकते हैं, जिन्हें एप्लिकेशन में उपयोग करने की आवश्यकता होती है। जब कई प्रोग्रामर एक एप्लिकेशन को कोड करते हैं, तो यह ऐसे मामले हो सकते हैं जहां एक व्यक्ति इंट, एक और डबल, और इसी तरह का उपयोग करता है। ऐसे संघर्षों से बचने के लिए, हम अक्सर डेटा प्रकारों के लिए उपयोग करते हैं। एक सरल उदाहरण नीचे दिखाया गया है।
उदाहरण
import std.stdio;
alias int myAppNumber;
alias string myAppString;
void main() {
myAppNumber i = 10;
myAppString s = "TestString";
writeln(i,s);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
10TestString
कक्षा चर के लिए उपनाम
अक्सर एक आवश्यकता होती है जहां हमें उपवर्ग में सुपरक्लास के सदस्य चर का उपयोग करने की आवश्यकता होती है, यह संभवतया एक अलग नाम के तहत, उपनाम के साथ संभव हो सकता है।
यदि आप कक्षाओं और विरासत की अवधारणा के लिए नए हैं, तो इस खंड से शुरू करने से पहले कक्षाओं और विरासत पर ट्यूटोरियल देखें ।
उदाहरण
एक सरल उदाहरण नीचे दिखाया गया है।
import std.stdio;
class Shape {
int area;
}
class Square : Shape {
string name() const @property {
return "Square";
}
alias Shape.area squareArea;
}
void main() {
auto square = new Square;
square.squareArea = 42;
writeln(square.name);
writeln(square.squareArea);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Square
42
उपनाम यह
उपनाम यह उपयोगकर्ता-परिभाषित प्रकारों के स्वचालित प्रकार रूपांतरणों की क्षमता प्रदान करता है। सिंटैक्स को नीचे दिखाया गया है जहाँ कीवर्ड उपनाम और यह सदस्य चर या सदस्य फ़ंक्शन के दोनों ओर लिखे गए हैं।
alias member_variable_or_member_function this;
उदाहरण
यह उर्फ की शक्ति दिखाने के लिए नीचे एक उदाहरण दिखाया गया है।
import std.stdio;
struct Rectangle {
long length;
long breadth;
double value() const @property {
return cast(double) length * breadth;
}
alias value this;
}
double volume(double rectangle, double height) {
return rectangle * height;
}
void main() {
auto rectangle = Rectangle(2, 3);
writeln(volume(rectangle, 5));
}
उपरोक्त उदाहरण में, आप देख सकते हैं कि इस आयत की सहायता से संरचना आयत को दोहरे मान में परिवर्तित किया जाता है।
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
30