Boolan_STL与泛型编程_第五周笔记

本周课程主要内容为标准库中STL之外的一些内容,包括一个万用的Hash Function、tuple、type traits、cout和moveable。

1、一个万用的Hash Function

这个万用的Hash Function有3种型式,如图1.1和图1.2,其中型式3是G4.9版本才有的新型式。

图1.1
图1.2
图1.3

本节内容总结如下:

(1)hash function设计原则:产生的hash code尽可能减少冲突, 使元素能够尽可能多的落在不同的篮子里;

(2)图1.3中,在①中加入了seed(最终被视为hash code),从而使得模板变成1+n的形式,通过递归调用②中的hash_val函数,不断调用④中的hash_combine函数来改变seed,同时减少接收的参数,最终递归结束时变成1+1的形式,调用③中的hash_val函数,也会调用④中的hash_combine函数,最终确认seed值,也就是算出最后的hash code;

(3)计算hash code时,0x9e3779b9是借用的黄金比例。

2、tuple

tuple是指元之组合,数之组合,它是C++2.0之后引进的一种存放各种不同类型元素的集合。

图2.1
图2.2

本节内容总结如下:

(1)创建一个四个元素的tuple t:

tuple<string,int,int,couple<double>>  t;//要标明每个元素的类型;

创建一个tuple,并赋初值:

tuple<int, float, string> t1(41, 6.3, "nice");

(2)get<0>(t1)取t1的第0个元素,get<1>(t1)取t1的第1个元素,以此类推;

(3)make_tuple 辅助函数直接放值,即创建一个tuple,并写入元素:

auto t2 = make_tuple(22, 44, "stacy"); 

(4)tuple的用法:

tie绑定,将tuple中对应的各个元素绑定到tie中,tuple_size获取tuple中value个数,tuple_element获取tuple中第几个元素的类型;

(5)tuple会自动递归,把元素分隔为head和tail, tail会再分隔为head和tail,直到tail只有一个元素为止,层层继承, tail作为基类,head作为数据成员;

(6)tuple是通过继承的方法来不断地剔除第一个参数,最终来实现对每一个元素的操作,而Hash Function是不断调用。

3、type traits

type traits用于回答class中的默认构造、拷贝构造、拷贝赋值、析构函数重要不重要,是否是POD等,为算法服务。

对于自定义的类型,可以自己定义type traits的特化版本。

图3.1
图3.2
图3.3
图3.4
图3.5
图3.6
图3.7

本节内容总结如下:

(1)string的析构函数不是虚函数,在设计上是不打算让用户继承的,所以询问是否有虚函数时是0.,是否有多态时是0;

(2)Zoo(const Zoo&) = delete; 不要编译器默认的。

Zoo(Zoo&&) = default; 要编译器默认的搬离构造函数, 用户不写时与其意义相同。

Zoo& operator=(const Zoo&) = default; 默认,用户不写时与其意义相同。

Zoo& operator=(const Zoo&&) = delete; 不要编译器默认的搬离赋值函数。

(3)对于is_void类模板,继承自_is_void_helper类模板,先把const、volatile属性拿掉,再传给__is_void_helper,利用它的泛化和特化void,判断是否是void;

(4)对于is_integral类模板,也是先把const、volatile属性拿掉,再利用__is_integral_helper的泛化和偏特化判断,如果不是和某种特化版本匹配的类型,那么就会使用泛化版本,泛化版本的回答是false;

(5)有些type traits的实现在标准库中找不到源代码,例如is_class、is_union、is_enmum、is_pod等,这种是由编译器实现的。

4、cout

cout是C++编程语言互换流中的标准输出流,需要iostream支持。

图4.1
图4.2

本节内容总结如下:

(1)cout是一个iostream类的对象,它有一个成员运算符函数operator<<,每次调用的时候就会向输出设备输出内容;

(2)从根本上说,cout是函数调用,不过这函数有些特殊,用的是运算符重载,确切地说是重载了“<<”运算符。

5、moveable

本节主要讲述moveable元素对于容器速度效能的影响,其中在vector中差别较大,在list、deque、multiset、unordered_multiset中差别不大。

图5.1
图5.2
图5.3
图5.4
图5.5

本节内容总结如下:

(1)在vector中拷贝300万个元素,调用MCtor或者CCtor的次数远大于300万次的原因是,容器vector是呈二倍成长的,每次增加容量均会调用MCtor或者CCtor;

(2)使用move虽无法减少拷贝的次数,但是可以提高拷贝构造的效率;

(3)move assignment、move constructor是浅拷贝;

(4)string具有moveable功能。

6、课后补充学习

traits的本质定义:加上一层间接性,换来以定的灵活性。

具体地说就是通过定义一些结构体或类,并利用模板类特化和偏特化的能力,给类型赋予一些特性,这些特性根据类型的 不同而异。traits在STL中为了提供通用的操作而又不损失效率在程序设计中可以使用这些traits来判断一个类型的一些特性,引发C++的函数重载机制,实现同一种操作因类型不同而异的效果。有人说 traits的编程技巧极度弥补了C++语言的不足 。

template <typename T>

structis_void

{staticconstboolvalue =false; };

template <>

structis_void

{staticconstboolvalue =true; };

Is_void<false>::value调用第一份代码,也就是说只要我们传入一个参数像这样:Is_void<T>::value,其中T可以为任意类型,我们就可以判断这个类型是不是void在编译期。

更详细的学习内容见:http://www.cnblogs.com/youthlion/archive/2011/12/01/2255618.html

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

推荐阅读更多精彩内容