首页 > 代码库 > template相关

template相关

  template模板是c++中支持多态的工具,使用模板可以使用户为类或函数声明一种一般的模式,使得该模板试用于任意类型的参数。

函数模板:

定义如下:

技术分享
template <typename T>
void swap(T& a , T& b){
    T temp;
    temp = a;
    a = b;
    b = temp;        
}
View Code

使用如下:

技术分享
#include<stdio.h>
int main(){
    int num1 = 0, num2 = 1;
    swap<int>(num1 , num2);
    printf("num1=%d,num2=%d\n",num1,num2);
    return 0;  
}
View Code

 

类模版:

定义如下:

技术分享
template<class T>
class Stack{
public:
    Stack();
    ~Stack();
    void push(T t);
    T pop();
    bool isEmpty();
private:
    int m_maxSize ;
    int m_size ;
    T *m_pT ;
}

template <class  T>  Stack<T>::Stack(){
   m_maxSize = 100;      
   m_size = 0;
   m_pT = new T[m_maxSize];
}
template <class T>  Stack<T>::~Stack() {
   delete [] m_pT ;
}
        
template <class T> void Stack<T>::push(T t) {
    m_size++;
    m_pT[m_size - 1] = t;
    
}
template <class T> T Stack<T>::pop() {
    T t = m_pT[m_size - 1];
    m_size--;
    return t;
}
template <class T> bool Stack<T>::isEmpty() {
    return m_size == 0;
}
View Code

类模版使用:

技术分享
#inlcude<stdio.h>

int main(){
    Stack<int> intStack;
    intStack.push(1);
    intStack.push(2);
    intStack.push(3);
    
    while (!intStack.isEmpty()) {
        printf("num:%d\n", intStack.pop());
    }
    return 0;
}    
View Code

模版参数:

模板除了有类型参数,也可以有普通的参数,也可以有默认的模板参数,例如:

template<class T, T def_val> 
class Stack{...}

如果想要对类模版的对象数量进行限制,可是使用int参数来配置这个累的最大对象数,如下:

技术分享
template <class T,int maxsize = 100> class Stack {
    public:
        Stack();
        ~Stack();
        void push(T t);
        T pop();
        bool isEmpty();
    private:
        T *m_pT;        
        int m_maxSize;
        int m_size;
};

template <class T,int maxsize> Stack<T, maxsize>::Stack(){
   m_maxSize = maxsize;      
   m_size = 0;
   m_pT = new T[m_maxSize];
}
template <class T,int maxsize>  Stack<T, maxsize>::~Stack() {
   delete [] m_pT ;
}
        
template <class T,int maxsize> void Stack<T, maxsize>::push(T t) {
    m_size++;
    m_pT[m_size - 1] = t;
    
}
template <class T,int maxsize> T Stack<T, maxsize>::pop() {
    T t = m_pT[m_size - 1];
    m_size--;
    return t;
}
template <class T,int maxsize> bool Stack<T, maxsize>::isEmpty() {
    return m_size == 0;
}
View Code

 

使用如下:

技术分享
#include <stdio.h>
int main() {
    int maxsize = 1024;
    Stack<int,1024> intStack;
    for (int i = 0; i < maxsize; i++) {
        intStack.push(i);
    }
    while (!intStack.isEmpty()) {
        printf("num:%d\n", intStack.pop());
    }
    return 0;
}
View Code

 

template相关