1. 程式人生 > >C++ 模板(一)

C++ 模板(一)

c++ 模板

C++模板類似與C#/Java當中的泛型,即可使用同樣的代碼實現不同的功能。效果類似於繼承(父對象指針指向子指針)。

一 : 函數模板

#include <iostream>
using namespace std;
template<typename T>//<typename T> == <class T>
void print( T a )
{
    cout<< a << endl;
}

int main()
{
    print(‘a‘);
    print(1);
    return 0;
}

結果:

技術分享

解析:

① template<typename T> 或者 template<class T>對函數print函數進行註冊模板。

② 註意如果註冊了泛型T , 那麽測函數一定要用到T。

③ template<typename T> 的作用域是這一整個函數。

④ 模板比重載要好用。


模板的具體化:當模板中有些情況需要具體處理的處理時(特殊處理)

#include <iostream>
using namespace std;
struct Note
{
    int a;
    int b;
};
template<typename T>//<typename T> == <class T>
void print( T a )
{
    cout<< a << endl;
}
//具體化特殊情況
template<> void print<Note>(Note a)
{
    cout << "具體化Note :" << a.a << endl;
}
int main()
{
    Note c;
    c.a = 10;
    print(c);
    return 0;
}

運行結果:

技術分享

解析:

① 直接打印Note的話絕對是會報錯的 , 這樣必須對Note的打印進行具體化

② 具體化的格式 : template<> void print<Note>(Note a)

③ 可以看出來template<typename T>void print( T a )根本就沒有執行,執行的是具體化的template<> void print<Note>(Note a),實際上如果有普通函數

void print(Note a ) , 則執行普通函數。 普通函數 > 具體化 > 模板


模板的實例化:

#include <iostream>
using namespace std;
struct Note
{
    int a;
    int b;
};
template<typename T>//<typename T> == <class T>
void print( T a )
{
    cout<< a << endl;
}
//具體化特殊情況
template<> void print<Note>(Note a)
{
    cout << "具體化Note :" << a.a << endl;
}
//實例化double類型
template void print<double>(double a);
int main()
{
    Note c;
    c.a = 10;
    print(c);
    return 0;
}

->template void print<double>(double a);

如果沒有調用print(12.12)( print(double))可以先實例化double,以後調用的話快一點,其余作用沒有。


二:類模板

#include <iostream>
using namespace std;
template<typename T = char>//如果是類模板,是可以加默認值的 T = char
class CPeople
{
public:
    T a;
    CPeople(T a)
    {
        this->a = a;
    }
    void print()
    {
        cout << a << endl;
    }
};
int main()
{
    CPeople<int> c_1(12);
    c_1.print();
    CPeople<> c_2(‘k‘);//因為默認泛型為char , 所以可以不寫char但是<>一定要帶上
    c_2.print();
    CPeople<double> * c_3 = new CPeople<double>(12.5);
    c_3->print();
    delete c_3;
    return 0;
}

結果:

技術分享

解析:

① template<typename T = char> 默認值在函數模板是不允許的。另外默認值和參數列表是一樣的,從右向左,不能 template<typename T = char,typename Y>只能template<typename T,typename Y=char>


類內定義 , 類外實現函數:

#include <iostream>
using namespace std;
template<typename T = char>//如果是類模板,是可以加默認值的 T = char
class CPeople
{
public:
    T a;
    CPeople(T a)
    {
        this->a = a;
    }
    void print();
};
template<typename T>
void CPeople<T>::print()
{
    cout << a << endl;
}
int main()
{
    CPeople<int> c_1(12);
    c_1.print();
    CPeople<> c_2(‘k‘);//因為默認泛型為char , 所以可以不寫char但是<>一定要帶上
    c_2.print();
    CPeople<double> * c_3 = new CPeople<double>(12.5);
    c_3->print();
    delete c_3;
    return 0;
}

註意函數模板不能用默認泛型

本文出自 “Better_Power_Wisdom” 博客,請務必保留此出處http://aonaufly.blog.51cto.com/3554853/1932109

C++ 模板(一)