源码之前,了无秘密  ——侯杰

  序列式容器                    关联式容器         

  array(build in)                  RB-tree

  vector                        set

    heap                        map

      priority-queue                multiset

  list                          multimap

  slist                       hashtable

  deque                        hash_set

    stack(配接器)                   hash_map

    queue(配接器)                  hash_multiset

                             hash_multimap

第四章:序列式容器                      

  C++语言本身提供了一个序列式容器array

  array:分配静态空间,一旦配置了就不能改变。

  vector:

    分配动态空间。维护一个连续线性空间,迭代器类型为:Random Access Iterators

    空间配置 typedef simple_alloc<value_type, Alloc> data_allocator

    所谓动态增加空间大小,并不是在原空间之后接续新空间,而是以原大小的两倍另外配置一块较大

    的空间,然后将原内容拷贝过来,然后才开始在原内容之后构造新元素,并释放原空间。因此,

    对vector的任何操作,一旦引起空间重新配置的话,指向原vector的所有迭代器就都失效了,

    这是程序员易犯的一个错误。

    可用的方法或函数:begin, end, size, capacity, empty, front, back, find, erase, clear, insert,

    push_back, pop_back

  list:非连续空间

//配置,释放,构造,销毁一个节点
protected:
//配置一个节点并传回
link_type get_node() {
return list_node_allocator::allocate();
}
//释放一个节点
void put_node(link_type) {
list_node_allocator::deallocate(p);
}
//产生(配置并构造)一个节点,带有元素值
link_type create_node(const T& x) {
link_type p = get_node();
construct(&p->data,x); //全局函数,构造/析构基本函数
return p;
}
//销毁(析构并释放)一个节点
void destroy_node(link_type p) {
destroy(&->data);
put_node(p);
}

  remove(const T& value) -> 将数值为values的所有元素移除

  void list<T,Alloc>::unique() ->移除数值相同的连续元素。注意是“连续”

  list的方法和函数: begin, end, empty, size, front, back,  find, insert, erase, clear, remove,

  push_front, push_back, pop_front, pop_back, unique, [ sort, splice, merge, reverse -> transfer

  deque:双向开口的连续线性空间,迭代器类型Random Access Iterator, 但是迭代器非常复杂,

  要维护一个地址队列

  与vector的差异:

      一在于deque可以常数时间内对起头端进行插入或移除操作

      二在于deque没有所谓容量的观念,动态的以分段连续空间组合而成,随时可以增加一段新的

      空间并链接起来。

  deque的最大任务,便是在这些分段的定量连续空间上,维护其整体连续的假象,并提供随机存取的接口,

  避开了重新配置,复制,释放的轮回,代价则是复杂的迭代器架构。

  deque的方法和函数:

  begin,end, empty, size, front, back, find, insert, erase, clear, push_front, push_back,

  pop_front, pop_back, reverse_map_at_back(size-type,node_to_add=1)

  reverse_map_at_front(size_type, node_to_add=1)

  stack:没有迭代器

  方法或函数:empty, size, top, push, pop     stack<int, list<int>> istack

  queue:empty, size, front, back, push, pop         queue<int, list<int>> iqueue

  heap:扮演priority queue的助手 使用binary max heap

  方法或函数:push_heap, pop_heap(first, last), sort_heap, make_heap

  

  priority_queue: empty,size, top, push, pop

  slist:单向链表

  方法或函数:size,begin,end, find, insert

重温《STL源码剖析》笔记 第四章的更多相关文章

  1. 《STL源码剖析》——第四章、序列容器

     1.容器的概观与分类 所谓序列式容器,其中的元素都可序(ordered)[比如可以使用sort进行排序],但未必有序(sorted).C++语言本身提供了一个序列式容器array,STL另外再提供v ...

  2. STL源码剖析读书笔记之vector

    STL源码剖析读书笔记之vector 1.vector概述 vector是一种序列式容器,我的理解是vector就像数组.但是数组有一个很大的问题就是当我们分配 一个一定大小的数组的时候,起初也许我们 ...

  3. c++ stl源码剖析学习笔记(一)uninitialized_copy()函数

    template <class InputIterator, class ForwardIterator>inline ForwardIterator uninitialized_copy ...

  4. 《STL源码剖析》读书笔记

    转载:https://www.cnblogs.com/xiaoyi115/p/3721922.html 直接逼入正题. Standard Template Library简称STL.STL可分为容器( ...

  5. 通读《STL源码剖析》之后的一点读书笔记

    直接逼入正题. Standard Template Library简称STL.STL可分为容器(containers).迭代器(iterators).空间配置器(allocator).配接器(adap ...

  6. 面试题总结(三)、《STL源码剖析》相关面试题总结

    声明:本文主要探讨与STL实现相关的面试题,主要参考侯捷的<STL源码剖析>,每一个知识点讨论力求简洁,便于记忆,但讨论深度有限,如要深入研究可点击参考链接,希望对正在找工作的同学有点帮助 ...

  7. 《STL源码剖析》相关面试题总结

    原文链接:http://www.cnblogs.com/raichen/p/5817158.html 一.STL简介 STL提供六大组件,彼此可以组合套用: 容器容器就是各种数据结构,我就不多说,看看 ...

  8. STL源码剖析之组件

    本篇文章开始,进行STL源码剖析的一些知识点,后续系列笔记全是参照<STL源码剖析>进行学习记录的 STL在现在的大部分项目中,实用性已经没有Boost库好了,毕竟STL中仅仅提供了一些容 ...

  9. 【STL 源码剖析】浅谈 STL 迭代器与 traits 编程技法

    大家好,我是小贺. 点赞再看,养成习惯 文章每周持续更新,可以微信搜索「herongwei」第一时间阅读和催更,本文 GitHub : https://github.com/rongweihe/Mor ...

  10. STL"源码"剖析-重点知识总结

    STL是C++重要的组件之一,大学时看过<STL源码剖析>这本书,这几天复习了一下,总结出以下LZ认为比较重要的知识点,内容有点略多 :) 1.STL概述 STL提供六大组件,彼此可以组合 ...

随机推荐

  1. webview与js交互

     对于android初学者应该都了解webView这个组件.之前我也是对其进行了一些简单的了解,但是在一个项目中不得不用webview的时候,发现了webview的强大之处,今天就分享一下使用we ...

  2. 手把手带你画一个 时尚仪表盘 Android 自定义View

    拿到美工效果图,咱们程序员就得画得一模一样. 为了不被老板喷,只能多练啊. 听说你觉得前面几篇都so easy,那今天就带你做个相对比较复杂的. 转载请注明出处:http://blog.csdn.ne ...

  3. 新手自定义view练习实例之(一) 泡泡弹窗

    转载请注明出处:http://blog.csdn.net/wingichoy/article/details/50455412 本系列是为新手准备的自定义view练习项目(大牛请无视),相信在学习过程 ...

  4. (十三)UITableView数据模型化

    多组数据的TableView的设计方法:每一组用一个模型对象表示. 模型包含了标题数据和行数据的数组,在控制器里包含模型的组来对各个模型进行初始化. 在tableView相应的方法中,从控制器的模型组 ...

  5. 本教程针对HBuilder5.0.0,制作日期2014-12-31(从HBuilder工具上获得)

     /*注:本教程针对HBuilder5.0.0,制作日期2014-12-31*/创建HTML结构: h 8 (敲h激活代码块列表,按8选择第8个项目,即HTML代码块,或者敲h t Enter)中 ...

  6. linux grep 和 sed使用

    http://www.cnblogs.com/zhuyp1015/archive/2012/07/01/2572289.html 听说过sed 和 awk 比较强大,专门学习了一下. 使用这些shel ...

  7. BASE64Decoder小解

    BASE64Decoder小解 Base64 是网络上最常见的用于传输8Bit 字节代码的编码方式之一,大家可以查看RFC2045 -RFC2049 ,上面有MIME 的详细规范. Base64 要求 ...

  8. Java-ServletContextAttributeListener

    /** Implementations of this interface receive notifications of ** changes to the attribute list on t ...

  9. Android群英传笔记——摘要,概述,新的出发点,温故而知新,可以为师矣!

    Android群英传笔记--摘要,概述,新的出发点,温故而知新,可以为师矣! 当工作的越久,就越感到力不从心了,基础和理解才是最重要的,所以买了两本书,医生的<Android群英传>和主席 ...

  10. PHP获取指定地区的天气

    在开发网站的时候用到天气查询,由于是基于Wordpress的 所以有很多限制,先建一个[weather.php]的文件,然后看代码: <?php //获取天气 $url = 'http://m. ...