一、如何进行泛型编程
 C/C++是一种静态编程语言,必须需要把代码翻译成可执行的二进制可执行程序然后再运行,一旦编译好之后就不能再变了(数据类型也就必须确定下无法更改,因此要为每一种数据类型编写一份算法,工程量巨大)。
 C语言中的快速排序:
 void qsort(void *base, size_t nmemb, size_t size,int(*compar)(const void *, const void *));
 C++提供了模板的编程方法来解决泛型编程的问题,它的解决思路是,程序员先编写好一份"套路"代码,然后在调用时编译器根据调用时的参数再为这种数据类型生成一份属于的它代码。
二、模板的语法

 template <typename T,typename M>
T max(T num1,M num1)
{
return num1>num2?num1:num2;
}
 练习:使用模板实现出一冒泡排序,能够被所有的数据类型所调用。
 
 T被称作模板的类型参数,可以叫任何名字,只是俗成约定叫作T。
 它指的是函数调用时的任何类型的参数。
 
 虽然模板的类型可以是任意的,但是必须要支持模板函数中所使用到的运算符,因此模板不是成能的,虽然能带来很多好处,但也带来了很多问题。
三、函数模板的使用
 1、模板的实例化
 编译器不会把函数模板编译成一个实例,而是根据调用时的参数,再进行实例化(进一步生成二进制指令)。
 2、使用模板时才实例化。
 模板只有在调用时才会实例化,因此模板编译正确并不代码没有问题,很多错误会产生于调用时。
 3、二次编译
 第一次是检查模板的语法,第二次编译是根据调用参数把模板实例化出来然后再检查运算符是否支持这种类型。
四、函数模板的隐式推断
 a、使用函数模板时可以根据参数的类型来推断模板的参数
 b、当函数模板不能通过函数调用时的参数来推断模板参数时,可以使用<类型,类型...>来明确指定。
 c、函数模板参数是可以有默认值的
  1、默认值什么放在右边
  2、C++标准才支持:-std=c++0x
五、函数模板与普通可以重载(特化)
 1、同一种格式的函数和函数模板是可以共生,但优先调用普通函数,但可以有函数名后添加一个空的<>指定调用函数模板,模板参数根据调用时的参数推断。
 
 2、普通函数在调用时可以进行类型提升,但是这种提升的结果要低于模板的实例化。
 3、函数模板也可以进行类型提升,但如果有一个普通函数也可以进行类型提升调用,那么则优先调用普通函数。
六、类模板
 a、类模板的语法
 类模板的参数可以在类中当作类型使用,可以定义成员、返回值、参数等。

 template<class T,class A,class B,...>
class className
{
C c;
public:
T func(A a);
};

注意:typename也可以继续使用,但大多用class以示区别。

 b、类模板的使用
 类模板必须要经过实例化才能使用,也是需要经过两次编译,第一次是把类模板编译成一个"套路",这个过程是为了检查语法,第二次是根据实例化参数,生成一个类,然后才能使用这个类创建对象。
 使用类模板实例化一个类:
 className<type1,type2,...> a;
 练习:实现栈类模板,成员函数有入栈、出栈、栈空、栈满。
 c、类模板参数不支持隐式推断,必须显示实例化。
 d、静态成员的定义的语法
  template<class T> int MyStack<T>::num = 10;
  静态成员必须在类模板实例化之后才被真正定义出来,每个实例化的类都有和份静态成员,这个实例化类创建出的对象共用一个静态成员。
 e、递归实例化
  MyStack<MyStack<int>> stack;
  尽量不要轻易使用。
七、类模板的特化(重载)
 特化:指的是当类模板有特殊的类型无法处理时,可以为这种特殊类型单独实例化出一个类,这种单独的实现叫作模板的特化。
 全类的第特化:按照类的格式把类完整再实现一遍(重写一遍)。

 template<> class className <char*>
{
...
};
 成员特化:给指定的类型提供一个特殊的的成员函数。

 template<> 返回值 className<char*>::max(void)
{
...
}
 局部特化:可以让用户根据实例化时的参数来指定使用的类模板

 template<class A,class B> class N
{public:N(void){cout <<""<<endl;}};
template<class A> class N <A,A>
{public:N(void){cout <<""<<endl;}};
template<class A> class N <A,short>
{public:N(void){cout <<""<<endl;}};
template<class A> class N <A*,A*>
{public:N(void){cout <<""<<endl;}};
template<class A,class B> class N <A*,B*>
{public:N(void){cout <<""<<endl;}};
 注意:同等程序的特化会引起二义性。
八、类模板的参数
 1、类模板的参数可以有默认值
  注意:使用类模板默认值时,<>不能省略,可以空着,但不能不写。 
 2、类模板后面的参数可以调用前面的参数。
 3、普通数值可以对类模板进行实例化,它必须以类似变量的形式存在。
 注意:只能是常量才能进行实例化。

模板与STL学习简单的笔记的更多相关文章

  1. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  2. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  3. 标准模板库(STL)学习指南之sort排序

    对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...

  4. 标准模板库(STL)学习指南之List链表

    本文转载自天极网,原文地址:http://www.yesky.com/255/1910755.shtml.转载请注明 什么是STL呢?STL就是Standard Template Library,标准 ...

  5. 标准模板库(STL)学习指南之priority_queue优先队列

    转载自CSDN博客:http://blog.csdn.net/suwei19870312/article/details/5294016 priority_queue 调用 STL里面的 make_h ...

  6. 标准模板库(STL)学习指南之set集合

    set是关联容器.其键值就是实值,实值就是键值,不可以有重复,所以我们不能通过set的迭代器来改变set的元素的值,set拥有和list相同的特性:当对他进行插入和删除操作的时候,操作之前的迭代器依然 ...

  7. 标准模板库(STL)学习指南之map映射

    转载自CSDN博客:http://blog.csdn.net/bat603/article/details/1456141 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...

  8. 标准模板库(STL)学习指南之vector向量

    vector – 一.  vector可以模拟动态数组 – 二.  vector的元素可以是任意类型T,但必须具备赋值和拷贝能力(具有public 拷贝构造函数和重载的赋值操作符) 三.必须包含的头文 ...

  9. 标准模板库(STL)学习探究之Multimap容器

    C++ Multimaps和maps很相似,但是MultiMaps允许重复的元素.(具体用法请参考map容器)     函数列表:     begin() 返回指向第一个元素的迭代器      cle ...

随机推荐

  1. asp.net六种方法刷新页面

    第一: private void Button1_Click( object sender, System.EventArgs e )   {     Response.Redirect( Reque ...

  2. MySQL 5.6 在线主从复制

    设:主库为master,从库为slave 1.备份主库数据(全库),且记录下 master_log_file,master_log_pos,用于后面设置slave时指定 备份脚本: mysqldump ...

  3. springweb flux 服务器推送事件

    以前做服务器推送一般用轮询,后端主动给客户端推送不是很好解决.有时候也可以采用websocket 现在看了springwebflux,用它自带的方法做服务器推送方便多了. 代码如下: import o ...

  4. C++11中多线程库

    一.Linux 线程API 线程是在操作系统层面支持的,所以多线程的学习建议还是先找一本linux系统编程类的书,了解linux提供线程的API,了解使用线程设计程序的基本操纵.完全使用系统调用编写多 ...

  5. Week5——团队选题&需求分析

    Deadline: 2017-10-22 10:00PM,以博客发表日期为准. 评分基准: 按时交 - 有分(团队选题-5分,,团队贡献分-5分,需求分析-10分,原型设计-10分),检查的项目包括后 ...

  6. [转]MVC中几种常用ActionResult

    本文转自:http://www.cnblogs.com/xielong/p/5940535.html 一.定义 MVC中ActionResult是Action的返回结果.ActionResult 有多 ...

  7. 关于webapi加入Route引用出现问题的解决方案

    首先在程序包管理器控制台运行安装MVC5.0,因为[Route("/api/..")]只会存在于MVC5.0中间,运行  Install-Package Microsoft.Asp ...

  8. [javaSE] 网络编程(TCP,UDP,Socket特点)

    UDP特点: 面向无连接,把数据打包发过去,收不收得到我不管 数据大小有限制,一次不能超过64k,可以分成多个包 这是个不可靠的协议 速度很快 视频直播,凌波客户端,feiQ都是UDP协议 TCP特点 ...

  9. 理解RESTFul和SOA

    RESTFul:面向资源的架构(roa) RESTFul基于HTTP协议,是一种明确构建在客户端/服务端体系结构上的一种风格, rest是Representational State Transfer ...

  10. C# 值类型 引用类型

    CLR 定义了两种类型,ReferenceTypes引用类型 和 ValueTypes 值类型.我们定义的各种Class都是引用类型,而我们用的decimal int 之类是值类型. 他们有什么区别呢 ...