四种GCC内置位运算函数

  • 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。

 

vs版

int builtin_clz(unsigned int type)//返回前导的0的个数
{
int num = 0;
type |=1; //防止type为0时,出现无限循环infinite loop,type为0时的计算结果为31。
while(!(type & 0x80000000)) //检测最高位是不是1。
{
num +=1;
type <<= 1;
}
return num;
}

posted @ 2016-05-23 11:26  wangyu2012  阅读(581)  评论(0编辑  收藏  举报