普通函数、函数重载、模板函数 认识。node
//学过c的童鞋们必定都写过函数sum吧,当时是这样写的: int sum(int a,int b) { return a+b; } //实现了整数的相加 //若是再想同时实现小数的相加,就再多写个小数的相加。普通实现我就不写了,知道函数重载的童鞋们会这样写: int sum(int a,int b) {//第一个function return a+b;} double sum(double a,double b) {//第二个function return a+b;} //这样咱们就能够只用一个sum函数 就能够实现整数相加与小数相加。 //可是这样咱们仍是要定义两个函数。 //C++考虑了怎么避免这种重复的操做,代码以下: 函数模板的声明。 template <typename T> T sum(T a,T b) {return a+b;} //只须要定义一个函数与只使用一个函数实现两数相加。
//函数模板---使用体现:调用函数时传递的参数类型。
template<class 数据类型参数标识符> <返回类型><函数名>(参数表) { 函数体 }
//结构体模板---使用体现:声明结构元素时 StackNode<类型> s;
template<class T>
struct StackNode
{
struct T data;
struct StackNode<T> *next;
};
//类模板---使用体现:声明类对象时 Stack<类型> s;
template<class T>
class Stack
{
public:
T pop();
bool push(T e);
private:
StackNode<T> *p;
}
template<class T>//类模板外的 成员函数实现
T Stack<T>::pop()
{...}
其中,template是定义模板函数的关键字;template后面的尖括号不能省略;class(或typename)是声明数据类型参数标识符的关键字,用以说明它后面的标识符是数据类型标识符。这样,在之后定义的这个函数中,凡但愿根据实参数据类型来肯定数据类型的变量,均可以用数据类型参数标识符来讲明,从而使这个变量能够适应不一样的数据类型。函数
①当你发现一套操做对多个不一样类型的变量操做时。例.咱们想实现链栈这个类,里面的元素能够是int char。学习
②实现的时候,那个链栈的头指针的类型就要为对应的 int节点、char节点...对应的指针类型。spa
③那就要复制粘贴 把int改为char 这样就有两个类 Stack_int Stack_char。指针
④用的时候固然没问题 可是整个类实现下来行数是不少的。当咱们看着多出那么多行只是 int char 不一样重复的代码,还容易写错。code
⑤模板的就是在 类的定义前面和外部类成员函数实现代码 加上template<class T> ps.没有分号,只有T能改。对象
⑥接着就是把 int char 的地方 所有改为 T。。。类名换成Stack就能够blog
⑦这样就造出来了 Stack_int与Stack_char 的一个模板io
⑧以前声明 对象的时候是{Stack_int a;Stack_char b;} 如今是{Stack<int> a;Stack<char> b;}function
完美了!!!感受模板只是把多个重复的代码化简成单个。。。。o.o。。。但确实好用。。。
①函数模板容许使用多个类型参数,但在template定义部分的每一个形参前必须有关键字typename或class,即:
template<class 数据类型参数标识符1,…,class 数据类型参数标识符n> <返回类型><函数名>(参数表) { 函数体 }
②在template语句与函数模板定义语句<返回类型>之间不容许有别的语句。以下面的声明是错误的:
template<class T> int I; T min(T x,T y) { 函数体 }
③模板函数相似于重载函数,但二者有很大区别:函数重载时,每一个函数体内能够执行不一样的动做,但同一个函数模板实例化后的模板函数都必须执行相同的动做。
④思在函数模板与模板函数调用之间 声明一个模板函数“相似”的函数,这参数会有一个隐式的转换!
1 template <class T>//结构体模板 2 struct node 3 { 4 T data; 5 struct node<T> *lchild; 6 struct node<T> *rchild; 7 }; 8 template <class T>//类内类模板 9 class bin 10 { 11 private: 12 node <T> h; 13 public: 14 void pri(); 15 }; 16 template <class T>//类外成员函数实现模板 17 void bin<T>::pri() 18 { 19 node<T> *p = new node; 20 cout<<"qunimade"<<endl; 21 } 22 int _tmain(int argc, _TCHAR* argv[]) 23 { 24 bin<int> abc; 25 }
2017-03-11 19:16:23 -> 2017-03-22 22:51:24 -> 2017-03-26 22:33:26