std::sort 没有小范围的自定义交换
在 C 中使用 std::sort 函数时,通常期望排序过程中将调用程序员提供的自定义交换函数。然而,在某些情况下,情况可能并非如此。具体来说,对于小数据范围,std::sort 的某些实现(例如 GCC 的 stdlibc 中的实现)可能会利用插入排序来进行性能优化。
插入排序优化
插入排序与 std::sort 使用的默认快速或介绍排序算法不同,不使用显式交换。相反,它通过移动数据元素块来实现排序顺序。这种方法比小范围内的单独交换更快。
在插入排序的内部实现中(在 GCC 4.7.2 中的 bits/stl_algo.h 中找到),使用 GLIBCXX_MOVE 和 _GLIBCXX_MOVE_BACKWARD3 执行数据移动功能。这些函数对应于 C 11 中的 std::move 和 std::move_backward。但是,如果未定义 __GXX_EXPERIMENTAL_CXX0X 宏,它们可能会诉诸复制而不是移动。
对自定义的影响交换
由于插入排序采用的优化,在小数据范围排序期间可能不会调用程序员定义的自定义交换函数。如果自定义交换函数的计算成本很高,这可能会特别令人担忧。
示例
考虑以下代码,其中实现了自定义交换函数和结构体向量A 已排序:
<code class="c++">namespace my_space { struct A { double a; double* b; bool operatora vec(n); for (int i = 0; i <p>对于像 n=4 这样的小范围,即使数组已正确排序,也不会调用自定义交换函数。发生这种情况是因为采用了插入排序,不需要显式交换。</p> <p><strong>结论</strong></p> <p>重要的是要注意 std::sort 可能并不总是使用自定义交换由于算法优化,适用于小数据范围。当使用昂贵的自定义交换函数时,这可能会产生影响。</p></code>
以上是** std::sort 是否始终调用小范围的自定义交换函数?**的详细内容。更多信息请关注PHP中文网其他相关文章!

本文解释了C标准模板库(STL),重点关注其核心组件:容器,迭代器,算法和函子。 它详细介绍了这些如何交互以启用通用编程,提高代码效率和可读性t

本文详细介绍了c中有效的STL算法用法。 它强调了数据结构选择(向量与列表),算法复杂性分析(例如,std :: sort vs. std vs. std :: partial_sort),迭代器用法和并行执行。 常见的陷阱

文章讨论了在C中有效使用RVALUE参考,以进行移动语义,完美的转发和资源管理,重点介绍最佳实践和性能改进。(159个字符)

本文详细介绍了C中的有效异常处理,涵盖了尝试,捕捉和投掷机制。 它强调了诸如RAII之类的最佳实践,避免了不必要的捕获块,并为强大的代码登录例外。 该文章还解决了Perf

C语言数据结构:树和图的数据表示与操作树是一个层次结构的数据结构由节点组成,每个节点包含一个数据元素和指向其子节点的指针二叉树是一种特殊类型的树,其中每个节点最多有两个子节点数据表示structTreeNode{intdata;structTreeNode*left;structTreeNode*right;};操作创建树遍历树(先序、中序、后序)搜索树插入节点删除节点图是一个集合的数据结构,其中的元素是顶点,它们通过边连接在一起边可以是带权或无权的数据表示邻

C 20范围通过表现力,合成性和效率增强数据操作。它们简化了复杂的转换并集成到现有代码库中,以提高性能和可维护性。

本文讨论了使用C中的移动语义来通过避免不必要的复制来提高性能。它涵盖了使用std :: Move的实施移动构造函数和任务运算符,并确定了关键方案和陷阱以有效

本文讨论了C中的动态调度,其性能成本和优化策略。它突出了动态调度会影响性能并将其与静态调度进行比较的场景,强调性能和之间的权衡


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver Mac版
视觉化网页开发工具