笔记
顺序容器的元素排列次序与元素值无关,而是由元素添加到容器的顺序决定。
#include<vector> #include<deque> #include<list>
- 初始化:
1)将一个容器初始化为另一个副本的副本:
vector<int> ivec; vector<int> ivec2(ivec);
2)使用迭代器间接初始化:
例:
c++
list<string> slist(svec.begin(),sevc.end());
vector<string>::iterator mid =svec.begin()+svec.size()/2;
deque<string> front(svec.begin(),mid);
指针就是迭代器,因此允许通过使用内置数组中的一对指针初始化容器。
例:
C++
char *words[]={"stately","plump","buck"};
size_t words_size=sizeof(words)/sizeof(char*);
list<string> words(words,words+words_size);
3)分配和初始化指定数目的元素:
const list<int>::size_type list_size=64;
list<string> slist(list_size,"asd");
容器大小可以是常量或非常量表达式。采用这种类型的初始化,元素类型(也就是尖括号中的类型),必须是内置或者符合类型,或者提供了默认构造函数的类类型。关联容器不支持。
4.容器可以放置类类型,但是不支持IO库类型,因为IO库类型不支持赋值或赋值。
5.vector< vector<string> >lines;
使用容器的容器时> >
中间必须有空格。
6.回忆:
在3 (2)中,sizeof(words)=12;
计算数组在内存中占的长度和单个“plump”这个字符串的长短无关。内存中数据中存放的是地址,不是实际的值。
sizeof(char*)=4;
一个指针4字节,32位机。
习题
9.3解释复制容器对象的构造函数和使用两个迭代器的构造函数之间的差别。
答:复制容器要求两个容器是同类型的;后者的话可以将一个容器初始化为另一个容器的子序列,而且不要求两个容器是同类型的。容器内的元素类型也可以不同,只要互相兼容即可。