码迷,mamicode.com
首页 > 其他好文 > 详细

四种GCC内置位运算函数

时间:2017-06-23 10:15:41      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:mod   版本号   track   tab   处理   parse   位运算   表示   uil   

  • int __builtin_ffs (unsigned int x)
    返回x的最后一位1的是从后向前第几位,比方7368(1110011001000)返回4。
  • int __builtin_clz (unsigned int x)
    返回前导的0的个数。
  • int __builtin_ctz (unsigned int x)
    返回后面的0个个数,和__builtin_clz相对。
  • int __builtin_popcount (unsigned int x)
    返回二进制表示中1的个数。

  • int __builtin_parity (unsigned int x)
    返回x的奇偶校验位,也就是x的1的个数模2的结果。

此外,这些函数都有对应的usigned long和usigned long long版本号,仅仅须要在函数名后面加上l或ll就能够了。比方int __builtin_clzll。

此外,基于稀疏表(Sparse Table)的RMQ问题,能够使用 __builtin_clz函数进行预处理。


四种GCC内置位运算函数

标签:mod   版本号   track   tab   处理   parse   位运算   表示   uil   

原文地址:http://www.cnblogs.com/slgkaifa/p/7068192.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!