函数模板和类模板

//函数模板---使用体现:调用函数时传递的参数类型。
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节点...对应的指针类型。

  ③那就要复制粘贴 把int改成char 这样就有两个类 Stack_int Stack_char。

  ④用的时候当然没问题 但是整个类实现下来行数是很多的。当我们看着多出那么多行只是 int char 不同重复的代码,还容易写错。

  ⑤模板的就是在 类的定义前面和外部类成员函数实现代码 加上template<class T> ps.没有分号,只有T能改。

  ⑥接着就是把 int char 的地方 全部改成 T。。。类名换成Stack就可以

  ⑦这样就造出来了 Stack_int与Stack_char 的一个模板

  ⑧之前声明 对象的时候是{Stack_int a;Stack_char b;}  现在是{Stack<int> a;Stack<char> b;}

使用中应该注意的问题:

  ①函数模板允许使用多个类型参数,但在template定义部分的每个形参前必须有关键字typename或class.

        ②在template语句与函数模板定义语句<返回类型>之间不允许有别的语句。

        ③模板函数类似于重载函数,但两者有很大区别:函数重载时,每个函数体内可以执行不同的动作,但同一个函数模板实例化后的模板函数都必须执行相同的动作。

  ④思在函数模板与模板函数调用之间 声明一个模板函数“类似”的函数,这参数会有一个隐式的转换.

猜你喜欢

转载自blog.csdn.net/florence_/article/details/81348363