我遇到了一个 #define
他们使用 __builtin_expect
。
文档 说:
内置函数:
long __builtin_expect (long exp, long c)
您可以使用
__builtin_expect
为编译器提供分支预测信息。一般来说,您应该更喜欢为此使用实际的配置文件反馈(-fprofile-arcs
),因为众所周知,程序员不善于预测他们的程序实际执行情况。但是,有些应用程序很难收集这些数据。返回值为
exp
的值,应该是整数表达式。内置的语义是期望exp == c
。例如:> if (__builtin_expect (x, 0)) > foo (); > > ``` > > 将表明我们不希望调用 `foo` ,因为我们希望 `x` 为零。 那么为什么不直接使用:
if (x) foo ();
”`
而不是 __builtin_expect
的复杂语法?
原文由 RajSanpui 发布,翻译遵循 CC BY-SA 4.0 许可协议
想象一下将从以下位置生成的汇编代码:
我想它应该是这样的:
您可以看到指令的排列顺序是
bar
案例在foo
案例之前(与 C 代码相反)。这可以更好地利用 CPU 流水线,因为跳转会破坏已经获取的指令。在执行跳转之前,它下面的指令(
bar
案例)被推送到管道。由于foo
情况不太可能发生,因此也不太可能发生跳跃,因此不太可能破坏管道。