Boolan C++ STL与泛型编程_5

主要内容:

标准库中除STL之外的内容。

1. 一个万用的hash function

  • hash function设计原则:产生的hash code尽可能减少冲突, 使元素能够尽可能多的落在不同的篮子里。
  • unordered_set两种使用方法:一种是针对需要存放的元素类型,定义泛函数。另一种是定义一个hash_function。
  • 设计hash function:


    hash function

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

2. tuple 元之组合,数之组合

  • eg. tuple<string, int, int, complex<double>> t; //sizeof(t) = 32.?
    tuple<int, float, string> t1(41, 6.3, "nice");
  • get<0>(t1)取t1的第0个元素。get<1>(t1)取t1的第1个元素...
  • auto t2 = make_tuple(22, 44, "stacy"); //创建一个tuple,并写入元素。
  • get<1>(t1) = get<1>(t2); //assign value
  • tuple之间可以比较大小。
    tie绑定,将tuple中对应的各个元素绑定到tie中。
    tuple_size获取tuple中value个数。
    tuple_element获取tuple中第几个元素的类型。
  • tuple会自动递归,把元素分隔为head和tail, tail会再分隔为head和tail, 直到tail只有一个元素为止。层层继承, tail作为基类,head作为数据成员。

3. type traits 类型萃取器

3.1 type_traits的定义
  • 回答class中的默认构造、拷贝构造、拷贝赋值、析构函数重要不重要、是否是POD(plain old data, c风格的结构,没有成员函数)等,默认是false。对于自己定义的类型,可以自己定义__type_traits的特化版本。
3.2 type_traits的使用
  • string的析构函数不是虚函数,string的设计上是不打算让用户继承的。has_virtual_destructor是0.,is_polymorphic(是否有多态)是0。

  • Zoo(const Zoo&) = delete; 不要编译器默认的。
    Zoo(Zoo&&) = default; 要编译器默认的搬移构造函数, 和用户不写意义相同。
    Zoo& operator=(const Zoo&) = default;
    Zoo& operator=(const Zoo&&) = delete; //不要编译器默认的搬移赋值函数。
    萃取器可以得知以上这四个函数是否需要编译器给的。

3.2 type_traits的实现原理
  • is_void的实现:is_void类模板继承自__is_void_helper类模板,首先对类型去除const、volatile属性,再传给__is_void_helper,利用它的泛化和特化void,判断是否是void。
  • is_integral的实现:也是先除去const和volatile属性,再利用__is_integral_helper的泛化和偏特化判断,如果不是和某种特化版本匹配的类型,那么就会使用泛化版本,泛化版本的回答是false。
  • 有些type_traits的实现找不到源代码,是由编译器实现的。

4. cout

sub_match对正则表达式的输出。
对自定义类型用cout输出,要重载<<.

5. moveable(c++11)

  • 两种拷贝方式:
    eg. M c11(c1);
    M c12(std::move(c1));
  • 对于红黑树的insert(ite, v1type(buf)), 如果不该放到ite指定的位置,还是会放到它应该放的位置。
  • vector如果不事先设置大小的话,那么当长度不够的时候要两倍增长,所以拷贝的次数就增多了,使用move虽无法减少拷贝的次数,但是可以提高拷贝构造的效率。
  • 对其他stl容器的拷贝构造的效率影响不大。
  • move assignment, move constructor是浅拷贝。
  • string是具有moveable的功能。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容