C++模板学习:函数模板、结构体模板、类模板

摘要:
C++模板:函数、结构、类模板实现1。前言:公共函数、函数重载、模板函数理解//C++考虑如何避免这种重复操作。代码如下:函数模板声明。④考虑在函数模板和模板函数调用之间声明一个模板函数“类似”。此参数将具有隐式转换!
C++模板:函数、结构体、类 模板实现

1.前言:(知道有模板这回事的童鞋请忽视)

  普通函数、函数重载、模板函数 认识。

//学过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;}
//只需要定义一个函数与只使用一个函数实现两数相加。

2.函数、结构体、类 模板的 定义样例:

//函数模板---使用体现:调用函数时传递的参数类型。
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)是声明数据类型参数标识符的关键字,用以说明它后面的标识符是数据类型标识符。这样,在以后定义的这个函数中,凡希望根据实参数据类型来确定数据类型的变量,都可以用数据类型参数标识符来说明,从而使这个变量可以适应不同的数据类型。

3.● 模板的基本思想 ●●●●●●

  ①当你发现一套操作对多个不同类型的变量操作时。例.我们想实现链栈这个类,里面的元素可以是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;}

完美了!!!感觉模板只是把多个重复的代码化简成单个。。。。o.o。。。但确实好用。。。

4.使用中应该注意的问题:

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

template<class 数据类型参数标识符1,…,class 数据类型参数标识符n>
<返回类型><函数名>(参数表)
{
     函数体
}

  ②在template语句与函数模板定义语句<返回类型>之间不允许有别的语句。如下面的声明是错误的:

template<class T>
int I;
T min(T x,T y)
{
   函数体
}

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

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

5.学习性代码:

 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

免责声明:文章转载自《C++模板学习:函数模板、结构体模板、类模板》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Nginx报错:Sorry, the page you are looking for is currently unavailable. Please try again later.windows 下VLC播放器应用之二LIBVLC API解析下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

海康SDK编程指南(C#二次开发版本)

海康SDK编程指南 目前使用的海康SDK包括IPC_SDK(硬件设备),Plat_SDK(平台),其中两套SDK都需单独调用海康播放库PlayCtrl.dll来解码视频流,返回视频信息和角度信息。本文仅对视频监控常用功能的使用进行说明,其它未实现功能请参看设备网络SDK使用手册和播放库编程指南V7.2。 IPC_SDK编程指南 (一) SDK的引用 由于I...

gin编写后端API的使用技巧

前言 之前在写练手的go项目的时候, 一方面确实觉得使用go来作为开发语言觉得顺手且速度快, 另一方面也感觉到了一些令人头疼的地方, 比如在编写某些接口时, 有一些复合查询的条件, 例如招聘网站的按 省市/地铁/商圈/工种/薪资/工龄/学历 等条件查询, 该查询是复合的, 你不知道每次用户选择的是哪些类型等等类似的问题, 本篇总结一下我是怎样去整理代码的,...

深入了解Windows句柄到底是什么(句柄是逻辑指针,或者是指向结构体的指针,图文并茂,非常清楚)good

总是有新入门的Windows程序员问我Windows的句柄到底是什么,我说你把它看做一种类似指针的标识就行了,但是显然这一答案不能让他们满意,然后我说去问问度娘吧,他们说不行网上的说法太多还难以理解。今天比较闲,我上网查了查,光是百度百科词条“句柄”中就有好几种说法,很多叙述还是错误的,天知道这些误人子弟的人是想干什么。 这里我列举词条中的关于句柄的叙述不...

TCP/IP网络编程系列之三(初级)

TCP/IP网络编程系列之三-地址族与数据序列 分配给套接字的IP地址和端口 IP是Internet Protocol (网络协议)的简写,是为首发网络数据而分配给计算机的值。端口号并非赋予计算机值,而是为了区分程序中创建的套接字而分配给套接字的序号。 网络地址 网络地址分为IPV4和IPV6,分别你别为4个字节地址簇和6个字节地址簇。IPV4标准的4个字...

(转)C#调用C函数(DLL)传递参数问题

备忘: 1.C函数参数为字符串char*。如果是入参,对应C#中string或StringBuilder;如果是出参对应C#中StringBuider; 2.C函数参数为结构体指针,需在C#中对应定义结构体。如果是入参,C#中可为myfunction(MyStruct mystruct)或myfunction(ref MyStruct mystruct);...

函数的返回值为结构体类型

可见,函数的返回值为结构体类型,其返回值既不是“值传递”也不是通过“寄存器”回传。编译器在编译此类函数时,为其附加了一个指针参数(指向的地址在caller的堆栈上),且作为函数的第一个参数(函数本身的参数依次后移),函数语义上的返回值通过该附加的指针参数回传,而函数真正的返回值就是该指针。 ————————————————版权声明:本文为CSDN博主「st...