STL与泛型编程学习笔记(二)

1 顺序容器

1.1 Stack

头文件<stack>

它是不允许遍历的,只能在顶端操作

调用s.top()函数只会返回顶端元素,不会改变指针

1.2 Queue

头文件<queue>

它也是不允许遍历的,只能在两端操作,从后面进去,从前面出来

2 关联容器

之前的都是顺序型的容器,下面的则是关联型的容器。

2.1 Map

头文件<set>

定义时必须指明,关键字key和值的型别

(第一个是关键字,第二个是值,可选的第三个是排序行为)

关键字一定是可排序的,有operator<

默认是用排序行为less(从小到大排序的仿函数类),对象的型别是第一个参数类别

可以通过仿函数来,自定义的排序行为

2.2 Multimap

跟map相似,但允许key重复的

2.3 Set

与map不同的是它只有key,也就是说key既是key又是value

删除和插入都和map相似

set相关算法:

set_union 用于合并,std::set_union(第一部份的开始,第一部份的结束,第二部分的开始,第二部分的结束,合并的目标位置的开始,排序行为)

set_intersection 将两部分相同的内容放到目标位置,语法跟上个算法一样

set_difference在第一部分中找出跟第二部分内容重复的去除,将第一部分剩下的放到目标位置里。语法一样。

要注意的问题

在排序的对象中,不用于排序的成员(非真正的key)是可以改变的,真正的key则不能的(排序行为决定了谁是真正的key),

改变方式是将迭代器指向的成员转为对象的引用

语法是 const_cast(*it).SetName(LBill Gates);

const_cast<新的型别>它是转换运算符中的一个。

STL整体结构

1.1仿函数

std::remove_if(v.begin(), v.end(), ContainsString(L”C++”));

remove_if()的调用中,规则ContainsString就用仿函数来实现,真正的函数是不能用来被作为参数传输的,所以要这样实现。

也是可以用函数指针来实现的,但函数指针的参数和返回型别必须是固定的,而且调用时也必须地精准匹配。函数指针也无法和STL其他组件交互。

仿函数可以用于实现容器的排序行为。注意:排序规则不同的容器是不同型别的,不能进行赋值和‘==’判断的。

2.1仿函数适配器

当仿函数与参数不能匹配时,适配器则可将仿函数变成可匹配的型别。

2.1.1 binder1st/binder2nd

std::vector::iterator it = std::find_if(v.begin(), v.end(), std::bind1st(std::not_equal_to(), 0));

在std::bind1st(std::not_equal_to(), 0))中的std::not_equal_to(1st, 2nd)是有需要两个参数的调用,而通过binder1st()定义,使0作为了它的左值(第一个参数),当调用时只需传入右值(第二参数)。

bind2nd 适配器的区别在于,作用于右值。

(算法“find_if(begin, end, func);”是从begin开始 ,到end为止,返回第一个能让 func这个函数返回true的值的iterator)

2.1.2 men_fun/men_fun_ref适配器

类的成员函数是不能和全局函数一样,单独被调用的,需要通过类的对象实现调用的。

而men_fun/men_fun_ref则可以实现类似这样子 “std::for_each(v.begin(), v.end(), &Person::Print)” 所愿望的功能。(将类Person中的成员函数Print传入for_each())(for_each(begin, end, func); 从begin到end为止,将每个值都给func)

std::vectorv;v.push_back(new Person(L”Tom”, 1));v.push_back(new Person(L”Jerry”,2));vpush_back(new Person(L”Micheal”,3));std::for_each(v.begin(), v.end(), std::men_fun(&Person::Print));

men_fun_ref 适配器,是在容器内容对象不是指针时使用。

std::vectorv;…std::for_each(v.begin(), v.end(), std::mem_fun_ref(&Person::Print));

(要注意的是,愿意是要传入成员函数的地址(作为函数指针),取函数地址是不用加上“()”的)

几个值得注意的问题

(1)std::string/std::wstring与vector<char>/vector<char>

    后者也是可以实现前者类似的功能的,但一般情况下是首选前者的。

    后者不能像前者那样有众多的功能成员函数,虽然后者可以调用一定数量的全局的功能函数。

    在多线程下可以考虑后者。

(2)容器里new出来的对象,记得在容器销毁前delete 

(3)尽量用算法代替手写循环将循环的内容写在仿函数里面

(4)通过swap为容器"缩水" 

    容器的size(大小)是实际占用,而capacity(容量)是可以通过v.reserve(1000); 这个操作预留出存放空间(这里是1000)。

    swap本身是用于替换的, 如果调用者是调用自身替换进行的话,像这样 “std::vector(v).swap(v);”,那么将会使它容量状态置为和size一样大小。 如果被替换的目标为空,像这样 “std::vector().swap(v)” 那么v会被消除。

(5) 当对象是子类,应该要建立指针容器

    因为对象装入容器内是把对象一个个地拷贝的。由于有继承的对象,在拷贝时,父类的部分会被切割,造成大量的性能开销。

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

推荐阅读更多精彩内容