栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++笔记 容器基础拾遗

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++笔记 容器基础拾遗

容器的关系运算符

简单例子

vector v1={1,3,5,7,9,12};
vector v2={1,3,9};
vector v3={1,3,5,7};
vector v4={1,3,5,7,9,12};

v1 
resize的用法 

resize用来改变容器的大小,resize不支持resize。顺序容器优先对容器的末尾进行操作。

//list泛指顺序容器
list ilist(10,42); // 10个值为42的int;
ilist.resize(15);//在末尾添加5个0
list.resize(25,-1);//在末尾添加10个-1(原有的值不发生变化)
list.resize(5);//删除后20个元素
容器的操作可能会使得迭代器失效

不同容器的不同操作对迭代器有不同的效果。

vector /stringdequelist/forward_list
添加若存储空间重新分配,则指向容器的迭代器,指针和引用失效。否则仍有效.在首尾之外添加元素会导致迭代器,指针引用均失效。否则只有迭代器失效迭代器,指针,引用仍有效。(因为是链式结构)
删除指向删除位置之前的迭代器,指针,引用仍有效。(尾后迭代器总是失效)在首尾之外的位置进行删除操作,会使所有迭代器,指针引用均失效。 删除首尾元素,则非删除位置的不失效。指向非删除位置的迭代器,指针,引用仍有效
容器的容量

vetcor将元素连续存储,为了支持快速随机访问。所以vector添加新元素时会分配比需求空间更大的内存空间作为备用。所以vector每次分配内存空间时都要移动所有的元素。(但还是比list和deque快。)

管理容量的成员函数

capacity和reserve不适用于deque.

c.shrink_to_fit();  将capacity减少到和size()相同
c.capacity();  不重新分配内存空间,c可以保存多少元素。
c.reserve(n);  分配n个元素的内存空间(但不实际添加元素)。
			   只有当前内存小于n个元素的内存的时候才会起作用

reserve只能增加容器的内存空间,不改变元素数量,不能减少容器的内存空间。
resize只改变元素数量,但不改变容量,所以也不能减少容器的内存空间

capacity表示当前内存空间能保存多少元素。
size表示已保存了多少元素。

string 额外操作

除了顺序容器通用的操作,string提供一些额外的操作.

1.构造

string s(cp,n); cp是字符数组 n是指前n个字符的拷贝
string s(s2,pos2); stirng.s2从下标pos2开始的拷贝。pos2 

2.分割

string("hello world");
s.substr(0,5);  hello
s.substr(6);  world
s.substr(6,11);  world
s.substr(12);  out_of_range异常

3.修改

string的insert和erase可接受下标
s.insert(pos,5,'!')    在s[pos]*之前*添加五个感叹号
s.erase(s.size()-5,5);    删除最后五个字符

insert和assign可接受c风格字符数组
const char*cp="Stately,plump BUCK";
s.assign(cp,7); s赋值cp的前七个字符
s.insert(s,size(),cp+7); 将前七个字符插入s[size]之前

append和replace string定义的两个额外成员函数
s.insert(s.size(),"world");
s.append("world");        两者等价

s.erase(11,3);
s.insert(11,"5th");  从11开始删除三个字符并插入5th
等价于
s.replace(11,3,"5th");
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/717919.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号