泛型程序设计的基本概念

编写不依赖于具体数据类型的程序

将算法从特定的数据结构中抽象出来,成为通用的

C++模板为泛型编程程序设计奠定了关键的基础

模型:符合一个概念的数据类型称为该概念的模型,例如:
int型是Comparable概念的模型;

静态数据类型不是Assignable概念的模型(无法用“=”给整个静态数组赋值)

用概念做模板参数名

很多STL的实现代码都是使用概念来命名模板参数的

为概念赋予一个名称,并使用这个名称作为模板参数名

表示insertionSort这样的一个函数模板的原型:

template <class Sortable> void insertionSort(Sortable a[], int n);

迭代器

迭代器是算法与容器的桥梁

  迭代器用作访问容器的元素

  算法不直接操作容器中的数据,而是通过迭代器间接操作;

输入迭代器与输出迭代器

输入迭代器

istream_iterator<T>

以输入流(如cin)为参数构造

可用*(p++)获得下一个输入的元素

输出流迭代器

ostream_iterator<T>

构造时需要提供输出流(如cout)

可用(*p++) = x 将x输出到输出流

两者都属于适配器

适配器是用来为已有对象提供新的接口的对象

输入流适配器和输出流适配器为流对象提供了迭代器的接口

#include <iterator>
#include <iostream>
#include <algorithm> using namespace std; double square(double x)
{
return x * x;
} int main()
{
transform(istream_iterator<double>(cin), istream_iterator<double>(),
ostream_iterator<double>(cout, "\t"), square);
cout << endl;
return ;
}

迭代器的辅助函数

advance(p,n)

对p执行n次自增操作

distance(first,last)

计算两个迭代器first和last的距离,即对first执行多少次++操作后first==last

容器的通用功能

相关数据类型(S表示容器类型)

S::iterator:指向容器元素的迭代器类型

S::const_iterator:常迭代器类型

随机访问容器

随机访问容器支持对容器元素进行随机访问

s[n]:获得容器s的第n个元素

顺序容器的特征

顺序容器:向量,双端队列,列表,单向列表,数组

向量:

特点:一个可以扩展的动态数组,随机访问,在尾部插入和删除元素比较快

双端队列

在两端插入或者删除元素比较快

在中间插入或者删除元素比较慢

随机访问比较快,但比向量容器慢

列表

在任意位置插入和删除元素狠快

不支持随机访问

顺序容器的比较

1.大量随机访问,且一般向容器尾添加元素,选择vector

注释:不能用下标形式给vector对象赋值,下标形式只能获取值;

2.少量随机访问,两端插入和删除元素,选择deque

3.无随机访问,中间插入或删除元素,选择list,或forward_list

顺序容器的插入迭代器和适配器

顺序容器的插入迭代器

用于向容器头部,尾部,或者中间指定位置插入元素的迭代器

包括前插迭代器(frontinserter),后插迭代器(backinserter),任意位置插入迭代器(inserter)

list<int> s;

back_inserter iter(s);

*(iter++)  = 5;//通过iter把5插入s末尾

栈和队列模板

栈模板

template<class T, class Sequence = deque<T> > class stack;

队列模板

template<class T,class FrontInsertionSequence = deque<T> > class queue;

栈可以用任何一种顺序容器作为基础容器,而队列只允许用前插顺序容器(双端队列或列表)

优先级队列

优先级队列也像栈和队列一样支持元素的压入和弹出,但元素弹出的顺序和元素的大小有关,每次弹出的总是容器中最“大”的一个元素;

template <class T,class Sequence = vector<T> > class priority_queue;

优先级队列的基础容器必须是支持随机访问的顺序容器;

C++学习笔记53:泛型程序设计与C++标准模板库的更多相关文章

  1. 8、泛型程序设计与c++标准模板库1、泛型程序设计的概念和术语

    有效地利用已有的成果,将经典的.优秀的算法标准化.模块化,从而提高软件的生产率,是软件产业化的需求,为了实现这一需求,不仅需要面向对象设计思想,而且需要泛型程序设计思想. c++语言提供的标准模板库( ...

  2. 8、泛型程序设计与c++标准模板库4.标准c++库中的算法

    标准c++算法是通过迭代器和模板来实现的,其实算法本身就是一种函数模板. 算法从迭代器那里获得一个元素,而迭代器则知道一个元素在容器中的什么位置.迭代器查找元素的位置并将这些信息提供给算法以便算法能够 ...

  3. 8、泛型程序设计与c++标准模板库5.函数对象

    1.函数对象 函数对象是STL提供的第四类主要组件,它使得STL的应用更加灵活方便,从而增强了算法的通用性.大多数STL算法可以用一个函数对象作为参数.所谓“函数对象”其实就是一个行为类似函数的对象, ...

  4. 第十章 泛型程序设计与C++标准模板库 泛型程序设计及STL的结构

  5. 8、泛型程序设计与c++标准模板库3.迭代器

    理解迭代器对于理解STL框架并掌握STL的使用至关重要.简单地说,迭代器是面向对象版本的指针,STL算法利用迭代器对存储在容器中的元素序列进行遍历,迭代器提供了访问容器和序列中每个元素的方法. 虽然指 ...

  6. 8、泛型程序设计与c++标准模板库2.5容器适配器

    容器适配器是用来扩展7中基本容器的,是修改和调整其他类接口的类.他们不提供存放数据的实际数据结构的实现方法,而且容器适配器也不支持迭代器. 1.标准栈容器 使用STL中的标准栈为程序员提供了一层附加的 ...

  7. 8、泛型程序设计与c++标准模板库2.4列表容器

    列表容器主要用于存放链表,其中的链表是双向链表,可以从任意一端开始遍历.列表容器是需要按顺序访问的容器.另外,列表容器不支持随机访问迭代器,因此某些算法不能适合于列表容器.列表容器还提供了另一种操作- ...

  8. 8、泛型程序设计与c++标准模板库2.3双端队列容器

    双端队列容器是一种放松了访问权限的队列.除了从队列的首部和尾部访问元素外,标准的双端队列也支持通过使用下标操作符"[]"进行直接访问. 它提供了直接访问和顺序访问方法.其头文件为& ...

  9. 8、泛型程序设计与c++标准模板库2.2向量容器

    向量容器属于顺序容器,用于容纳不定长线性序列(即线性群体),提供对序列的快速随机访问(也称直接访问).这一点与c++语言支持的基本数组类型相同,但基本数据类型不是面向对象的.而面向对象的向量是动态结构 ...

随机推荐

  1. 【TensorFlow】基于ssd_mobilenet模型实现目标检测

    最近工作的项目使用了TensorFlow中的目标检测技术,通过训练自己的样本集得到模型来识别游戏中的物体,在这里总结下. 本文介绍在Windows系统下,使用TensorFlow的object det ...

  2. C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why?

    C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why? 简单粗暴的答案:存在Cache机制! 稍微啰嗦一点:CPU访问内存(读/写,遍历数组的话主要是读) ...

  3. JCenter下载太慢, jcenter修改 https为http也许能帮助你

    今天导入一个工程到studio,一直卡在下载那块. 看到下载地址是:https://jcenter.bintray.com/........https!!!! 到浏览器下载,果然也下载不下来.. 于是 ...

  4. 解决Windows Server 2008R2通过计划任务定时执行bat文件,显示成功但实际未执行

    前段时间在Windows Server 2008安装了一套基于MySQL数据库的软件,处于数据安全的考虑,希望每天能够自动进行数据库备份.我在别人脚本的基础上自己写了一个数据库备份的bat脚本,双击该 ...

  5. 一脸懵逼学习hadoop之HDFS的java客户端编写

    1:eclipse创建一个项目,然后导入对应的jar包: 鼠标右击项目,点击properties或者alt+enter快捷键--->java build path--->libraries ...

  6. [转] 浅谈session,cookie,sessionStorage,localStorage的区别及应用场景

    浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用cookie,session等跟服务端进行数据交互. 一.cookie和session cookie和session都是用来跟踪浏览器 ...

  7. Lambda表达式树构建(上)

    概述 Lambda是C#常用的语句,采用委托等方式,来封装真实的代码块.Lambda其实就是语法糖,是一个匿名函数,是一种高效的类似于函数式编程的表达式,Lambda简化了开发中需要编写的代码量.它可 ...

  8. jloi2015

    题解: [JLOI2015]管道连接 这个很水 比较裸的斯坦纳树dp 斯坦纳树dp就是 g[i][j]表示当前在i点,状态为j 然后转移分为两种 g[i][j]=g[i][k]+g[i][k^j] 另 ...

  9. 1.RN环境搭建,创建项目,使用夜神模拟调试

    1.环境搭建(Yarn.React Native 的命令行工具(react-native-cli)) npm install -g yarn react-native-cli 具体参考 参见官方(中文 ...

  10. 51Nod1309 Value of all Permutations 期望

    原文链接https://www.cnblogs.com/zhouzhendong/p/51Nod1309.html 题目传送门 - 51Nod1309 题意 长度为N的整数数组A,有Q个查询,每个查询 ...