美文网首页
GeekBand-笔记-05

GeekBand-笔记-05

作者: 诵之思之 | 来源:发表于2016-11-21 20:30 被阅读0次

总结:侯老师的这门stl课,只看视频和ppt是不太够的。应该结合侯老师的《stl源码剖析》和Nicolai M Josuttis的《The C++ Standard Libaray》两本书进行学习。

STL组件:容器、迭代器、算法、分配器、适配器、仿函数

容器:序列式容器、关联式容器、无序容器

序列式容器:array、vector、deque、list、forward_list,都属于有序集合

关联式容器:set、multiset、map、multimap,都属于已排序集合

无序容器:unordered_set、unordered_multiset、unordered_map、unordered_multimap,都属于无序集合

容器的共通能力:

缺省构造

拷贝构造

移动构造(不适用于array)

empty,判断容器是否为空,相当于size()==0的判断,但可能更快

size,返回容器中元素数量,不适用于forward_list

max_size,返回元素的最大可能数量

swap或者::swap,置换两个容器的数据

一些基本操作如==,!=,<=、>=、<、>等

begin,返回一个迭代器,指向第一个元素

cbegin,如上,但返回的迭代器是const的

end,返回指向最末元素下一位置的迭代器

cend,如上,但迭代器是const的

clear,移除所有元素,令容器为空,不适用于array

ARRAY:

提供正反向迭代器

c.fill(val) 将val赋值给array c的每一个元素

c[idx],返回索引idx指向的元素,不检查范围

c.at(idx),返回索引idx指向的元素,超出范围就抛出range-error异常

c.front,返回第一元素,不检查是否存在第一元素

c.back,返回最末元素,不检查是否存在最末元素

c.rbrgin、c.rend、c.crbegin、c.crend,返回迭代器,类似通用的,但是逆向的

因为标准库保证array的实现一定是内存连续的,可以将其按照c-style的数组来用。但是!注意!c.begin不保证返回首地址,请使用c.data

注意!array提供tuple接口!

VECTOR:

提供正反向迭代器

Capacity,返回实际可容纳的最大元素数量,若超过这个量,则vector就有必要重新分配内部内存,此时,相关的引用、指针、迭代器全部失效

Reserve,可以指定适当的容量

Shrink_to_fit,可以缩减容器容量以适应当前元素个数,但这不是强制性的

c[idx],返回索引idx指向的元素,不检查范围

c.at(idx),返回索引idx指向的元素,超出范围就抛出range-error异常

c.assign(n,elem),赋值n个elem赋值给c

c.assign(beg,end),将[beg,end]区间内的元素赋值给c

c.assign(initlist),将初值列initlist内的所有元素赋值给c

c.front,返回第一元素,不检查是否存在第一元素

c.back,返回最末元素,不检查是否存在最末元素

c.rbrgin、c.rend、c.crbegin、c.crend,返回迭代器,类似通用的,但是逆向的

c.push_back,附加一个元素的拷贝在末尾

c.pop_back,移除最后一个元素但是不返回它

c.insert(pos,elem),在pos前方处插入元素elem的拷贝并返回新元素的位置

c.insert(pos,n,elem),在pos前方处插入n个elem的拷贝并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,beg,end),在pos前方插入区间[beg,end]内的所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,initlist),在pos前方插入初值列initlist内所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.emplace(pos,args。。。),在pos前插入一个以args为初值的元素,并返回新元素的位置

c.emplace_back(args…),附加一个以args为初值的元素以末尾,不返回任何东西

c.erase(pos),移除pos上的元素,返回下一元素的位置

c.erase(beg,end),移除[beg,end]区间内的所有元素,返回下一元素的位置

c.resize(num),元素数量改为num,如果size()变大,多出来的新元素都会以缺省构造函数完成初始化

c.resize(num,elem),把元素数量改为num,如果size()变大则多出来的元素都是elem的拷贝

c.clear,移除所有元素,清空容器

因为标准库保证vector的实现一定是内存连续的,可以将其按照c-style的数组来用。但是!注意!c.begin不保证返回首地址,请使用c.data

注意!一个特例!vector<bool>

DEQUE

提供正反向迭代器

注意!deque与vector的操作函数大部分相同,除了:

1、
不提供容量操作,capacity和reserve

2、
提供头部元素的安插和删除:push_front和pop_front以及emplace_front

Shrink_to_fit,可以缩减容器容量以适应当前元素个数,但这不是强制性的

c[idx],返回索引idx指向的元素,不检查范围

c.at(idx),返回索引idx指向的元素,超出范围就抛出range-error异常

c.assign(n,elem),赋值n个elem赋值给c

c.assign(beg,end),将[beg,end]区间内的元素赋值给c

c.assign(initlist),将初值列initlist内的所有元素赋值给c

c.front,返回第一元素,不检查是否存在第一元素

c.back,返回最末元素,不检查是否存在最末元素

c.rbrgin、c.rend、c.crbegin、c.crend,返回迭代器,类似通用的,但是逆向的

c.push_back,附加一个元素的拷贝在末尾

c.pop_back,移除最后一个元素但是不返回它

c.insert(pos,elem),在pos前方处插入元素elem的拷贝并返回新元素的位置

c.insert(pos,n,elem),在pos前方处插入n个elem的拷贝并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,beg,end),在pos前方插入区间[beg,end]内的所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,initlist),在pos前方插入初值列initlist内所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.emplace(pos,args。。。),在pos前插入一个以args为初值的元素,并返回新元素的位置

c.emplace_back(args…),附加一个以args为初值的元素以末尾,不返回任何东西

c.erase(pos),移除pos上的元素,返回下一元素的位置

c.erase(beg,end),移除[beg,end]区间内的所有元素,返回下一元素的位置

c.resize(num),元素数量改为num,如果size()变大,多出来的新元素都会以缺省构造函数完成初始化

c.resize(num,elem),把元素数量改为num,如果size()变大则多出来的元素都是elem的拷贝

c.clear,移除所有元素,清空容器

LIST

提供正反向迭代器

List不支持随机访问

List不提供容量、空间重新分配等函数

List提供不少特殊的成员函数。专门用于移动和移除元素。这类函数比同名的STL的通用算法更快!比如remove和remove_if

提供头部元素的安插和删除:push_front和pop_front以及emplace_front

c.assign(n,elem),赋值n个elem赋值给c

c.assign(beg,end),将[beg,end]区间内的元素赋值给c

c.assign(initlist),将初值列initlist内的所有元素赋值给c

c.front,返回第一元素,不检查是否存在第一元素

c.back,返回最末元素,不检查是否存在最末元素

c.rbrgin、c.rend、c.crbegin、c.crend,返回迭代器,类似通用的,但是逆向的

c.push_back,附加一个元素的拷贝在末尾

c.pop_back,移除最后一个元素但是不返回它

c.insert(pos,elem),在pos前方处插入元素elem的拷贝并返回新元素的位置

c.insert(pos,n,elem),在pos前方处插入n个elem的拷贝并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,beg,end),在pos前方插入区间[beg,end]内的所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.insert(pos,initlist),在pos前方插入初值列initlist内所有元素的一份拷贝,并返回第一个新元素的位置,或者返回pos—如果没有新元素的话

c.emplace(pos,args。。。),在pos前插入一个以args为初值的元素,并返回新元素的位置

c.emplace_back(args…),附加一个以args为初值的元素以末尾,不返回任何东西

c.erase(pos),移除pos上的元素,返回下一元素的位置

c.erase(beg,end),移除[beg,end]区间内的所有元素,返回下一元素的位置

c.resize(num),元素数量改为num,如果size()变大,多出来的新元素都会以缺省构造函数完成初始化

c.resize(num,elem),把元素数量改为num,如果size()变大则多出来的元素都是elem的拷贝

c.remove(val),移除所有值为val的元素

c.remove_if(op),移除所有op(elem)为true的元素

c.clear,移除所有元素,清空容器

待续……

相关文章

  • GeekBand-笔记-05

    总结:侯老师的这门stl课,只看视频和ppt是不太够的。应该结合侯老师的《stl源码剖析》和Nicolai M J...

  • iOS开发 -- 开发应用的步骤

    这是我个人的学习笔记 , 如有不同见解欢迎评论交流 . ( GeekBand-极客班 http://geekban...

  • iOS开发 -- 属性与成员变量

    这是我个人的学习笔记 , 如有不同见解欢迎评论交流 . ( GeekBand-极客班 http://geekban...

  • iOS开发--事件监听处理

    这是我个人的学习笔记 , 如有不同见解欢迎评论交流 .( GeekBand-极客班 http://geekband...

  • iOS开发--Objective-C的多继承

    这是我个人的学习笔记 , 如有不同见解欢迎评论交流 . ( GeekBand-极客班 http://geekban...

  • GeekBand-笔记-06

    safari下的jianshu根本无法直接粘贴剪贴板里的图像啊。请到网易云课堂笔记那儿下载附件,谢谢! 一、标准容...

  • GeekBand-笔记-02

    一、三大函数 1、拷贝构造 带指针成员的class必须有。因为兄弟之间互相是friend,所以可以直接取另一个ob...

  • GeekBand-笔记-01

    一、C++程序设计风格 1、过程式程序设计 2、基于对象 3、面向对象 4、泛型 二、头文件的防卫式声明 1、#i...

  • GeekBand-笔记-04

    一、 vptr && vtable1、基本上C++传统意义上的多态,就来自vptr和vtable2、要深入...

  • GeekBand-笔记-03

    一、转换函数 1、conversion operator是class的一种特殊的member function,其...

网友评论

      本文标题:GeekBand-笔记-05

      本文链接:https://www.haomeiwen.com/subject/khoupttx.html