标准模板库就是类与函数模板的大集合。STL共有6种组件:容器,容器适配器,迭代器,算法,函数对象和函数适配器。
1、容器:
容器是用来存储和组织其他对象的对象。STL容器类的模板在标准头文件中定义。主要如下所示
①序列容器
基本的序列容器是上面图中的前三类:
关于三者的优缺点主要是:
A:vector
矢量容器的操作:(自己以前有个表,贴出来大家看看)
其中的capacity表示容量,size是当前数据个数。矢量容器如果用户添加一个元素时容量已满,那么就增加当前容量的一半的内存,比如现在是500了,用户添加进第501个,那么他会再开拓250个,总共就750个了。所以矢量容器当你添加数据量很大的时候,需要注意这一点哦。。。
如果想用迭代器访问元素是比较简单的,使用迭代器输出元素的循环类似如下:
vector::iterator表示矢量容器vector的迭代器。。。
for(vector::iterator iter = number.begin(); iter
当然也可以用我们自己的方法,但是感觉用上面的更好一些。
for(vector::size_type i=0; i
排序矢量元素:
对矢量元素的排序可以使用
B:deque
deque
#include
deque data;//创建双端队列容器对象
deque::iterator iter;//书序迭代器
deque::reverse_iterator riter;//逆序迭代器。
//iter和riter是不同的类型
C:list
②关联容器
map
有关它的创建以及查找的操作作如下总结
//创建映射容器
map phonebook;
//创建要存储的对象
pair entry = pair(person("mel", "Gibson"), "213 345 567");
//插入对象
phonebook.insert(entry);//只要映射中没有相同的键,就可以插入entry
//访问对象
string number = phonebook[person("mel", "Gibson")];//如果这个键不存在,会默认将这个键插入
//如果不想在找不到的时候插入,可以先查找然后再检索
person key = person("mel", "Gibson");
map::iterator iter = phonebook.find(key);//创建迭代器,就认为是指针就好了
if(iter != phonebook.end())
string number = iter->second;
2、容器适配器:
容器适配器是包装了现有的STL容器类的模板类,提供了一个不同的、通常更有限制性的功能。具体如下所示
A:queue
代码:queue
B:priority_queue
默认情况下,优先级队列适配器类使用的是矢量容器vector
priority_queue, greate> numbers;
//定义容器
stack people;
//基于列表来定义堆栈
stack> names;
3、迭代器:
具体它的意思还没怎么看明白,书上介绍迭代器的行为与指针类似,这里做个标记,看看后面的例子再给出具体的解释
具体分为三个部分:输入流迭代器、插入迭代器和输出流迭代器。
、
看这一章的内容看的我有点抑郁了都,摘段课本介绍的内容,还是可以帮助理解的
输入流迭代器用下面的程序来说明下,可见具体注释
#include
#include
#include
#include
using namespace std;
int main()
{
//定义矢量容器
vector numbers;
cout << "请输入整数值,以字母结束:";
//定义输入流迭代器。注意两个不同
//1、numberInput(cin)是指定迭代器指向流cin
//2、numbersEnd没有指定,是默认的,默认构造了一个end_of_stream的迭代器,它等价于调用end()
istream_iterator numbersInput(cin), numbersEnd;
//用户输入,直到输入的不是int类型或者终止时结束。
while(numbersInput != numbersEnd)
numbers.push_back(*numbersInput++);
cout << "打印输出:" << numbers.at(3) << endl;
//如何指定输入流呢?
//确定字符串
string data("2.1 3.6 36.5 26 34 25 2.9 63.8");
//指定data为输入流input。需要头文件
istringstream input(data);
//定义迭代器
istream_iterator begin(input), end;
//计算数值和。
//acculumate为头文件下定义的函数。
//第一个参数是开始迭代器,第二个是终止迭代器(最后一个值的下一个)。第三个是和的初值,注意必须用0.0,用它确定数据类型是double
cout << "打印数据的总和:" << accumulate(begin, end, 0.0) << endl;
}
输出结果:
耽误时间太多。以后再写吧
4、算法:
算法是操作迭代器提供的一组对象的STL函数模板,对对象的一个操作,可以与前面的容器迭代器结合起来看。如下图介绍
5、函数对象:
函数对象是重载()运算符的类类型的对象。就是实现operator()()函数。
函数对象模板在
6、函数适配器:
函数适配器是允许合并函数对象以产生一个更复杂的函数对象的函数模板。