likely,unlikely宏与GCC内建函数__builtin_expect()

      在/include/linux/Compiler.h中遇到了unlikely宏定义和一个GCC内建函数__builtin_expect(),查阅GCC手册,发现其定义如下:

      long __builtin_expect (long exp, long c)                                    [Built-in Function]
      You may use __builtin_expect to provide the compiler with branch prediction information. In general, you should prefer to use actual profile feedback for this (‘-fprofile-arcs’), as programmers are notoriously bad at predicting how their programs actually perform. However, there are applications in which this data is hard to collect.
      The return value is the value of exp, which should be an integral expression. The value of c must be a compile-time constant. The semantics of the built-in are that it is expected that exp == c. For example:
      if (__builtin_expect (x, 0))
        foo ();
would indicate that we do not expect to call foo, since we expect x to be zero. Since you are limited to integral expressions for exp, you should use constructions such as
      if (__builtin_expect (ptr != NULL, 1))
        error ();
when testing pointer or floating-point values.

      大致是说,由于大部分程序员在分支预测方面做得很糟糕,所以GCC提供了这个内建函数来帮助程序员处理分支预测,优化程序。其第一个参数exp为一个整型表达式,这个内建函数的返回值也是这个exp,而c为一个编译器常量,这个函数的语义是:你期望exp表达式的值等于常量c,从而GCC为你优化程序,将符合这个条件的分支放在合适的地方。

      因为这个程序只提供了整型表达式,所以如果你要优化其他类型的表达式,可以采用指针的形式。


unlikely的定义如下:

#define unlikely(x)  __builtin_expect(!!(x), 0)

也就是说我们期望表达式x的值为0,从而如果我们用

…….

if(unlikely(x)){

bar();

}
来测试条件的话,我们就不期望bar()函数执行,所以该宏的名字用unlikely也就是不太可能来表示。

likely宏与次类似.


说到底__builtin_expect函数就是为了优化可能性大的分支程序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值