gcc里的__builtin_..

使用范围:

gcc : __builtin_functionLastName(x)只适应于无符号整型
但对于有符号正整数:它自动转换无符号整型,计算结果不会影响
具体使用看下面代码注释!!

测试代码:

#include 
using namespace std;
int lowbit(int x)
{
    return x&-x;

} //x&-x 等价于 x&(~x+1)
int main()
{
    //gcc : __builtin_functionLastName(x)只适应于无符号整型

    int x = 26;//11010
   //x = -26;//计算出错
    cout<<"计算x = 26(11010)的二进制1的个数,__builtin_popcount(x) = "<<__builtin_popcount(x)<<endl;//计算x的二进制1的个数
    x = 84;//1010100
    cout<<"计算x = 84(1010100)末尾0的个数,__builtin_ctz(x) = "<<__builtin_ctz(x)<<endl;//计算x的二进制末尾0的个数
    x = 204;//11001100
    cout<<"返回x = 204(11001100)的二进制最后一个1的位置,__builtin_ffs(x) = "<<__builtin_ffs(x)<<"  lowbit(x) = "<<lowbit(x)<<endl;
    /*
    __builtin_ffs(x) : 返回x的二进制最后一个1的位置(从后向前数,最后一个1在第几个bit位)
     lowbit(x) : 返回最后一个1该位置对应的2的幂 的值
    */
    x = 84;
    unsigned int x1 = 84;
    cout<<"byte of unsigned int  = "<<sizeof(x1)<<endl;//4个字节
    cout<<"x = 84(1010100),前置0的个数:"<<__builtin_clz(x)<<" "<<__builtin_clz(x1)<<endl;//前置0的个数(共32位)
    x = 84,x1 = 204;
    //1010100  11001100
    cout<<"x = 84(1010100),x1 = 204(11001100),二进制1的个数的奇偶性:"<<"x:"<<__builtin_parity(x)<<" x1:"<<__builtin_parity(x1)<<endl;
    //1的个数奇数(1)or 偶数(0)
    return 0;
}

测试结果:
gcc里的__builtin_.._第1张图片

你可能感兴趣的:(STL)