GeekBand-笔记-05

总结:侯老师的这门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,移除所有元素,清空容器

待续……

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 模板 模板是C++语言相对较新的一个重要特性。模板使程序员能够快速建立具有类型安全的类库集合和函数集合,它的实现,...
    帅碧阅读 988评论 2 4
  • STL(Standard Template Library)里有很多组成部分,但是主要有三个,容器、迭代器和算法 ...
    再想想1991阅读 881评论 0 1
  • C++基础 模板及标准模板库 模板的作用模板使程序员能够快速的建立具有类型安全得库集合和函数集合,它的实现,方便了...
    I踏雪寻梅阅读 525评论 0 4
  • 其实从外观上看,这条路与旁的路并无区别,晴天里灰尘会四散飞扬,阴雨天则泥泞不堪,以往每天走在上面的人很多,数量恐怕...
    风染一瓣阅读 971评论 0 2
  • 儿童培训机构如何发礼品 今天听一个朋友说,他孩子的培训机构孩子上课,现在每次课都送孩子礼物,孩子可高兴...
    之乎者也06阅读 558评论 0 0