当前位置:   article > 正文

unlikely和likely函数作用_unlikely函数

unlikely函数

linux内核中的判断语句里常见到unlikely和likely函数。
如:

if(unlikely(a)) // if(likely(a))
{
	...
}
else
{
...
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

两函数实质是__builtin_expect的的宏定义,原型如下:

# define likely(x)	__builtin_expect(!!(x), 1)
# define unlikely(x)	__builtin_expect(!!(x), 0)
  • 1
  • 2

__builtin_expect 是GCC的内置函数,用来对选择语句的判断条件进行优化,常用于一个判断条件经常成立(如likely)或经常不成立(如unlikely)的情况。
__builtin_expect的函数原型为long __builtin_expect (long exp, long c),返回值为完整表达式exp的值,它的作用是期望表达式exp的值等于c(注意,如果exp == c条件成立的机会占绝大多数,那么性能将会得到提升,否则性能反而会下降)。而likely和unlikely是__builtin_expect函数的参数c=1(true)和0(false)的情况。

因此:
if(unlikely(a))和if(likely(a))的执行等价于if(a)是 一样的,区别在于unlikely和likely函数的加入会优化编译,加likely的意思是value的值为true的可能性更大一些,编译时会将if里的代码编译到紧跟likely判断后面;而unlikely表示value的值为fale的可能性更大一些,编译时会将else下面的代码指令编译到紧跟unlikely判断之后。这样做目的可以提高CPU指令判断效率,减少指令跳转而降低性能
·

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/333828
推荐阅读
相关标签
  

闽ICP备14008679号