自定义模板 memcmp 与 C memcmp
Custom template memcmp vs C memcmp
template <typename T>
int custom_memcmp(const T* a, const T* b, std::size_t n);
这会比C的memcmp更快吗?
如果 sizeof(T) != 1:它将执行较少的迭代,并且可以将值作为其实际类型进行比较。例如,除了直接比较两个"长长"之外,我不会比比较两个 8 字节缓冲区更快。
memcmp
通常是编译器内部的,因此将进行优化以尽可能高效(将被矢量化,内联等)。
所以你几乎肯定不会打败它。 但是,当然,如果您想确定,那么只需个人资料!
不,它不会更快。 MEMCMP 将尽可能高效地比较适当大小的原始内存。 只有 memcmp 的天真实现才能逐字节完成。
相关文章:
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 如何将点击的信号和插槽添加到qt中的自定义按钮中
- C++自定义比较函数
- 如何比较自定义类的std::变体
- std::设置自定义比较器
- 如何正确实现和访问运算符的各种自定义枚举器
- flutter:即使shouldRepaint()返回true,自定义画家也不会重新绘制
- 自定义先决条件对移动分配运算符有效吗
- 使用VS Code和CMake Tools运行自定义命令
- 如何创建从Maya(或类似程序)到虚幻引擎的自定义数据导出插件
- std::ranges::elements_view,用于自定义类似元组的数据
- 跟随整数索引列表的自定义类迭代器
- 参数化自定义CMake工具链
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 如何在自定义类中启用'auto loops'?
- 使用QJsEngine在Qt中注册自定义类型
- Qt自定义QPush按钮未显示在布局上
- 自定义对象的dlib序列化在gcc中失败
- 自定义创建QFuture
- 自定义模板 memcmp 与 C memcmp