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,移除所有元素,清空容器

待续……

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

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