C ++ टेम्प्लेट

टेम्प्लेट जेनेरिक प्रोग्रामिंग की नींव होते हैं, जिसमें कोड लिखना इस तरह से होता है जो किसी विशेष प्रकार से स्वतंत्र होता है।

जेनेरिक क्लास या फ़ंक्शन बनाने के लिए एक खाका एक खाका या सूत्र है। पुस्तकालय कंटेनर जैसे पुनरावृत्तियों और एल्गोरिदम सामान्य प्रोग्रामिंग के उदाहरण हैं और टेम्पलेट अवधारणा का उपयोग करके विकसित किए गए हैं।

प्रत्येक कंटेनर की एक एकल परिभाषा है, जैसे कि vector, लेकिन हम उदाहरण के लिए कई अलग-अलग प्रकार के वैक्टर को परिभाषित कर सकते हैं, vector <int> या vector <string>

आप कार्यों के साथ-साथ कक्षाओं को परिभाषित करने के लिए टेम्पलेट्स का उपयोग कर सकते हैं, आइए देखें कि वे कैसे काम करते हैं -

फंक्शन टेम्पलेट

टेम्पलेट फ़ंक्शन परिभाषा का सामान्य रूप यहां दिखाया गया है -

template <class type> ret-type func-name(parameter list) {
   // body of function
}

यहां, फ़ंक्शन द्वारा उपयोग किए जाने वाले डेटा प्रकार के लिए एक प्लेसहोल्डर नाम है। यह नाम फ़ंक्शन परिभाषा के भीतर उपयोग किया जा सकता है।

निम्नलिखित एक फ़ंक्शन टेम्पलेट का उदाहरण है जो अधिकतम दो मान लौटाता है -

#include <iostream>
#include <string>

using namespace std;

template <typename T>
inline T const& Max (T const& a, T const& b) { 
   return a < b ? b:a; 
}

int main () {
   int i = 39;
   int j = 20;
   cout << "Max(i, j): " << Max(i, j) << endl; 

   double f1 = 13.5; 
   double f2 = 20.7; 
   cout << "Max(f1, f2): " << Max(f1, f2) << endl; 

   string s1 = "Hello"; 
   string s2 = "World"; 
   cout << "Max(s1, s2): " << Max(s1, s2) << endl; 

   return 0;
}

यदि हम कोड को संकलित और चलाते हैं, तो यह निम्नलिखित परिणाम देगा -

Max(i, j): 39
Max(f1, f2): 20.7
Max(s1, s2): World

कक्षा का खाका

जिस तरह हम फंक्शन टेम्प्लेट को परिभाषित कर सकते हैं, उसी तरह हम क्लास टेम्प्लेट को भी परिभाषित कर सकते हैं। सामान्य श्रेणी की घोषणा का सामान्य रूप यहाँ दिखाया गया है -

template <class type> class class-name {
   .
   .
   .
}

यहाँ, type प्लेसहोल्डर प्रकार का नाम है, जो तब निर्दिष्ट किया जाएगा जब एक वर्ग को तत्काल किया जाता है। आप अल्पविराम से अलग की गई सूची का उपयोग करके एक से अधिक सामान्य डेटा प्रकार परिभाषित कर सकते हैं।

निम्न वर्ग स्टैक <> को परिभाषित करने और स्टैक से तत्वों को धकेलने के लिए सामान्य तरीके लागू करने के लिए उदाहरण है -

#include <iostream>
#include <vector>
#include <cstdlib>
#include <string>
#include <stdexcept>

using namespace std;

template <class T>
class Stack { 
   private: 
      vector<T> elems;    // elements 

   public: 
      void push(T const&);  // push element 
      void pop();               // pop element 
      T top() const;            // return top element 
      
      bool empty() const {      // return true if empty.
         return elems.empty(); 
      } 
}; 

template <class T>
void Stack<T>::push (T const& elem) { 
   // append copy of passed element 
   elems.push_back(elem);    
} 

template <class T>
void Stack<T>::pop () { 
   if (elems.empty()) { 
      throw out_of_range("Stack<>::pop(): empty stack"); 
   }
   
   // remove last element 
   elems.pop_back();         
} 

template <class T>
T Stack<T>::top () const { 
   if (elems.empty()) { 
      throw out_of_range("Stack<>::top(): empty stack"); 
   }
   
   // return copy of last element 
   return elems.back();      
} 

int main() { 
   try {
      Stack<int>         intStack;  // stack of ints 
      Stack<string> stringStack;    // stack of strings 

      // manipulate int stack 
      intStack.push(7); 
      cout << intStack.top() <<endl; 

      // manipulate string stack 
      stringStack.push("hello"); 
      cout << stringStack.top() << std::endl; 
      stringStack.pop(); 
      stringStack.pop(); 
   } catch (exception const& ex) { 
      cerr << "Exception: " << ex.what() <<endl; 
      return -1;
   } 
}

यदि हम कोड को संकलित और चलाते हैं, तो यह निम्नलिखित परिणाम देगा -

7
hello
Exception: Stack<>::pop(): empty stack