C++候捷stl-视频笔记4

一个万用的hash function

哈希函数的形式,一种是一般函数(右边),一种是成员函数(左边),类的对象将成为函数对象

具体做法例子。直接把属性的所有hash值加起来,会在hashtable中会产生很多的碰撞,放在同一个bucket中的元素会多

另一种是使用可变模板参数来做的hash_val()函数,产生种子,经过复杂的操作,得到hash值。

版本1接受任意个数模版参数,版本2函数参数第一个是size_t(版本1产生的seed),重复调用版本2,直到剩一个模版参数,调用版本3

利用struct hash的偏特化来实现hash function

特化实现例子

Tuple用例

tuple用法示例

tuple<Head, Tail...> 继承 tuple<Tail...>

通过递归定义使得 tuple 类模板可以方便地处理可变数量的模板参数,每一层递归处理一个参数。这也是元编程中常见的技术,通过递归和继承来处理可变数量的参数。

type traits

默认的 __type_traits 进行了一系列泛化的设定



traits测试例子

type traits实现

is_void

cpp 复制代码
// 通过范围偏特化实现remove const
template <typename _Tp>
struct remove_const
{ typedef _Tp type };
template <typename _Tp>
struct remove_const<_Tp const>
{ typedef _Tp type };
// remove volatile 同理

is_integral

cout

各种类对<<操作符的重载,以实现在标准输出设备上输出

movable元素对于不同容器速度效能的影响

由于vector的底层会两倍空间扩展,在扩展的时候会调用拷贝构造,所以这里调用次数为7194303,明显大于三百万



内存实际非连续的容器影响不大

move操作就是"浅拷贝",用新指针指向数据,打断旧指针


对于 vector 这样的容器,其用 move 就只是 swap 了三根指针

string带有movable的功能,从&&右值可以看出

相关推荐
知识领航员7 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪7 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
AOwhisky7 小时前
虚拟化技术学习笔记
linux·运维·笔记·学习·虚拟化技术
一只机电自动化菜鸟7 小时前
一建机电备考笔记(33) 机电专业技术(起重技术-吊装方案)(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
jf加菲猫8 小时前
第21章 Qt WebEngine
开发语言·c++·qt·ui
小陈phd9 小时前
多模态大模型学习笔记(四十)——从“看字”到“懂结构”:版面分析与表格解析技术全解
笔记·学习
xuhaoyu_cpp_java9 小时前
SpringMVC学习(二)
java·经验分享·笔记·学习·spring
码农-阿杰9 小时前
深入理解 synchronized 底层实现:从 HotSpot C++ 源码看对象锁与 Monitor 机制
开发语言·c++·
Szime9 小时前
深智微IC华润微代理:MCU选型与工业控制方案推荐
c++
叼烟扛炮10 小时前
C++ 知识点18 内部类
开发语言·c++·算法·内部类