现代C++程序应该使用标准库容器,而不是更原始的数据结构,例如内置数组。

新标准库容器的性能几乎肯定与最精心优化过的同类数据结构一样好。

当我们用一个对象来初始化容器时,或将一个对象插入到容器中时,实际上放入到容器中的是对象值的拷贝,而不是对象本身。

  • 容器选择原则
  1. 除非你有很好的理由选择其他容器,否则应使用vector;
  2. 如果你的程序有很多小的元素,且空间的额外开销很重要,则不要使用list或forward_list;
  3. 如果程序要求随机访问元素,应使用vector或deque;
  4. 如果程序需要在头尾位置插入或删除元素,而不会再中间位置插入或删除,使用deque;
  5. 如果程序只有在读取输入时才需要在中间位置插入元素,随后需要随机访问元素,则:
  • 首先确定是否真的需要在容器中间位置添加元素。(可以在vector中追加数据,然后sort重排)
  • 如果必须添加元素,则考虑输入阶段使用list;一旦完成,将list的内容copy到一个vector中。

Best Practice:如果不确定应该使用哪种容器,那么可以在程序中只使用vector和list的公共操作:使用迭代器。不使用下标操作,避免随机访问。

为了创建一个容器为另一个容器的拷贝,两个容器的类型及其元素类型必须匹配。不过,当传递迭代器参数来拷贝一个范围时,就不要求容器类型是相同的了,而且元素类型可以转换即可。

 list<string> authors = { "Milton","Shakespeare","Austen" };
vector<const char*> articles = { "a", "an","the" }; list<string> list2(authors);//正确
vector<string> authors2(authors);//错误,容器类型不匹配
list<string> words(articles.begin(), articles.end());//正确
list<const string> ls(authors);//错误

虽然内置数组不能进行copy或者对象赋值工作,但array并没有这种限制。

由于右边运算对象的大小可能与左边运算对象的大小不同,因此array类型不支持assign,也不允许用花括号列表来赋值(但是可以初始化)

 array<int, > digits = { ,,, };
array<int, > copy = digits;//正确 array<int, > a1 = { ,,, };
a1 = { ,,, };//错误

swap:除array外,交换两个容器内容的操作会很快——元素本身并未交换,swap只是交换两个容器的内部数据结构。swap两个array会真正交换它们的元素。

  • 向容器中插入/删除元素

push_back(t), push_front(t),返回void;

insert(p,t), insert(p,n,t), insert(p,b,e), insert(p,il) 实在迭代器p元素之前插入元素,返回指向新添加的(第一个)元素的迭代器。

emplace_front(args), emplace_back(args),emplace(p,args)这些操作构造而不是拷贝元素。是将参数传递给元素类型的构造函数。emplace成员使用这些参数在容器管理的内存空间中直接构造元素。而调用push_back则会创建一个局部临时对象,并将其压入容器中。

  • 删除元素

pop_back(), pop_front(), clear()返回void;

erase(p),erase(b,e)删除元素,返回一个指向(最后)被删元素之后元素的迭代器;

  • forward_list

没有简单办法来获得前驱,所以其删除/插入都是after版本。

insert_after(p,t),insert_after(p,n,t),insert_after(p,b,e),insert_after(p,il),emplace_after(p,args)在迭代器p之后插入元素,返回一个指向最后一个插入元素的迭代器

erase_after(p), erase_after(b,e)删除p指向的位置之后的元素,返回一个指向北山元素之后元素的迭代器。

  • string的数值转换

新标准引入了多个函数,可以实现数值数据与标准库string之间的转换

to_string(val),

stoi/stoul/stol/stoll/stoull(s,p,b):返回s起始子串(表示整数部分)的数值,b表示基数,默认为10。P是size_t指针,用来保存s第一个非数值字符的下标。

stof/stod/stold(s,p)

Chapter9:顺序容器的更多相关文章

  1. Chapter9(顺序容器) --C++Prime笔记

    PS:删除元素的成员函数并不检查其参数.在删除元素之前,程序员必须确保它们是存在的. 1.迭代器的范围是[begin,end)左闭右开. 2.对构成迭代器的要求: ①它们指向同一个容器中的元素或者容器 ...

  2. C++ 顺序容器基础知识总结

    0.前言 本文简单地总结了STL的顺序容器的知识点.文中并不涉及具体的实现技巧,对于细节的东西也没有提及.一来不同的标准库有着不同的实现,二来关于具体实现<STL源码剖析>已经展示得全面细 ...

  3. c++ 顺序容器学习

    所谓容器,就是一个装东西的盒子,在c++中,我们把装的东西叫做“元素” 而顺序容器,就是说这些东西是有顺序的,你装进去是什么顺序,它们在里面就是什么顺序. c++中的顺序容器一共有这么几种: vect ...

  4. C++ Primer 第九章 顺序容器

    由于书籍上写的已经很经典了,故大部分用图片的形式来阐述概念,代码纯手打进行验证. 1.顺序容器类型:vector.deque.list.forword_list.array.string. 2.顺序容 ...

  5. C++学习基础四——顺序容器和关联容器

    —顺序容器:vector,list,queue1.顺序容器的常见用法: #include <vector> #include <list> #include <queue ...

  6. C++ 顺序容器

    <C++ Primer 4th>读书笔记 顺序容器内的元素按其位置存储和访问.容器类共享公共的接口,每种容器类型提供一组不同的时间和功能折衷方案.通常不需要修改代码,只需改变类型声明,用一 ...

  7. C++ Primer : 第九章 : 顺序容器的操作以及迭代器失效问题

    顺序容器的添加.访问.删除操作以及forward_list的特殊操作,还有迭代器失效问题. 一.向容器添加元素 // array不支持这些操作 // forward_list有自己撰于的版本的inse ...

  8. C++ Primer : 第九章 : 顺序容器的定义、迭代器以及赋值与swap

    顺序容器属于C++ STL的一部分,也是非常重要的一部分. 顺序容器包括: std::vector,包含在头文件<vector>中 std::string, 包含在头文件<strin ...

  9. 顺序容器:vector,deque,list

    1.顺序容器:vector,deque,list 容器类共享公共接口,只要学会其中一种类型就能运用另一种类型.每种容器提供一组不同的时间和功能这种方案,通常不需要修改代码,秩序改变类型声明,每一种容器 ...

  10. C++ Primer 随笔 Chapter 9 顺序容器

     参考:http://www.cnblogs.com/kurtwang/archive/2010/08/19/1802912.html 1..顺序容器:vector(快速随机访问):list(快速插入 ...

随机推荐

  1. mysql插入中文数据报错:incorrect string value

    我是用的source指令来执行sql脚本文件时发现的这个错误 我的数据库用创建的时候create Database If Not Exists XXXXXX Character Set UTF8; 那 ...

  2. backbone todo example

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 开发板上修改时间方法date命令【转】

    转自:http://blog.chinaunix.net/uid-25906157-id-3138157.html 之前使用开发板时发现每次开机后,系统的时间都恢复到初始状态1970年. 一. 先说一 ...

  4. WP7应用版本升级的实现方法

    首先必须要有一个服务提供升级推送查询 // Code to execute when the application is launching (eg, from Start)         //  ...

  5. hdu2847(暴力)

    去年看的一道题目,但是竟然傻傻的用dfs+循环链表去做. 简直傻到爆.  不过现在做这题还是想了好久而且还有好几次WA,其实这题还是很水的.直接暴力枚举就行了,枚举的前提是要算好复杂度, 可以知道的是 ...

  6. C#克隆实例详解

    public AtmDataBase DeepClone() { MemoryStream ms = new MemoryStream(); BinaryFormatter bf = new Bina ...

  7. 基于百度地图js进行地理定位

    http://www.mengxiangchaoren.com/jquery.select.position.min.js 使用方法 $("#myCity").renderSele ...

  8. HDU 2602 (简单的01背包) Bone Collector

    很标准的01背包问题 //#define LOCAL #include <algorithm> #include <cstdio> #include <cstring&g ...

  9. 一个基于WebGL的仿真3D水池有逼真的水波纹效果

    最近在研究WebGL,看到国外很多高手做的很多超炫的3D效果,无比羡慕.忍不住把效果趴下来研究,下面介绍一个逼真的游泳池中浮动小球的效果.效果非常绚丽,功能强大.示例可切换观察水池的视角,不同视角考虑 ...

  10. LeetCode Reverse Nodes in k-Group 每k个节点为一组,反置链表

    题意:给一个单链表,每k个节点就将这k个节点反置,若节点数不是k的倍数,则后面不够k个的这一小段链表不必反置. 思路:递归法.每次递归就将k个节点反置,将k个之后的链表头递归下去解决.利用原来的函数接 ...