• C语言位操作


    C语言中,有时需要进行置位操作,比如针对其中的某些位。这样做的目的是既达到了目标,又不会影响其它位。常用的置位操作如下:

    #define   setbit(x,y)    x|=(1<<y) //将X的第Y位置1
    #define   clrbit(x,y)     x&=~(1<<y) //将X的第Y位清0

          举个例子:

    int main(int argc, char* argv[])
    {
          unsigned char a = 0x55;
          unsigned char b = a|(1<<1);      //第一位置1
          unsigned char c = a&~(1<<2);   //第二位置0
          printf("Hello World! 0x%x,0x%x/n",b,c);
          return 0;
    }

    输出0x57,0x51。0x57即从01010101,变成01010111;0x51即从01010101,变成01010001。

    一、基本位操作

    |

    &

    ~

    取反

    ^

    异或

    <<

    左移

    >>

    右移

    二、位操作的常见用法

    1.获取某位的值

    1. #define BitGet(Number,pos) ((Number)|= 1<<(pos)) //把某位置1 
    2. #define BitGet(Number,pos) ((Number) &= ~(1<<(pos)) //把某位置0
    3. #define BitGet(Number,pos) ((Number) >> (pos)&1)) //用宏得到某数的某位
    4. #define BitGet(Number,pos) ((Number) ^= 1<<(pos)) //把Number的POS位取反

    2.设定某位的值(设为0或1)

    方法一:

    1. #define setbit(x,y) x|=(1<<y) //将x的第y位置1 
    2. #define clrbit(x,y) x&=~(1<<y) //将x的第y位清0

    方法二:

    置0,用0去‘与’

    int a|=(1<<x) x就是某位需要置1的数字,如第四位置1为:="" a|="(1<<4)

    置1,用1去‘或’ 
    int a&=~(1<<x) 把某位置0<="" p="">

    3.循环移位

    1. #define ROTATE_LEFT(x, n) ((x) << (n)) | ((x) >> ((8 * sizeof(x)) - (n))) 
    2. #define ROTATE_RIGHT(x, n) ((x) >> (n)) | ((x) << ((8 * sizeof(x)) - (n)))

    4.计算绝对值

    1. int abs(int x) 
    2.     int y; 
    3.     y = x>>31; 
    4.     return (x^y)-y; //or:(x+y)^y 
    5. }
     5.判断整数的符号
    1. int sign(int x) 
    2.     return (x>>31)|(unsigned(-x))>>31;
    3. }
     6.两个数比较
    1.   x==y: ~(x-y|y-x) 
    2.   x!=y: x-y|y-x 
    3.   x<y:      (x-y)^((x^y)&((x-y)^x)) 
    4.   x<=y: (x|~y)&((x^y)|~(y-x)) 
    5.   x<y: (~x&y)|((~x|y)&(x-y))//无符号x,y比较 
    6.   x<=y: (~x|y)&((x^y)|~(y-x))//无符号x,y比较
    7.交换两个数的值(swap)
    1. 1.x ^= y ; y ^= x ; x ^= y ;
    2. 2.x = x+y ; y = x-y ; x = x-y ;
    3. 3.x = x-y ; y = y+x ; x = y-x ;
    4. 4.x = y-x ; x = y-x ; x = x+y ;
    8.位计数
    1. 方法一:
    2. int count(long v)
    3. {
    4.     int number = 0;
    5.  
    6.     while(v)
    7.     {
    8.         v &= (v-1);
    9.         number++;
    10.     }
    11.     return number;
    12. }
    13. 方法二:
    14. int count(unsigned x) 
    15.     x = x-((x>>1)&0x55555555) ; 
    16.     x = (x&0x33333333)+(x>>2)&0x33333333); 
    17.     x = (x+(x>>4))&0x0f0f0f0f; 
    18.     x = x+(x>>8); 
    19.     x = x+(x>>16); 
    20.     return x&0x0000003f; 
    21. }
     9.二进制和GRAY码的转换
    1. (1).二进制码到GRAY码的转换: 
    2.   unsigned B2G(unsigned B ) 
    3.   { 
    4.       return B ^ (B>>1) ; 
    5.   } 
    6.   (2).GRAY码到二进制码: 
    7.   unsigned G2B(unsigned G) 
    8.  {
    9.      unsigned B ; 
    10.      B = G ^ (G>>1) ; 
    11.      B = G ^ (G>>2) ; 
    12.      B = G ^ (G>>4) ; 
    13.      B = G ^ (G>>8) ; 
    14.      B = G ^ (G>>16) ; 
    15.      return B ;
    16.   }
    10.位反转
    1. unsigned rev(unsigned x) 
    2.     x = (x & 0x55555555) << 1 | (x>>1) & 0x55555555 ; 
    3.     x = (x & 0x33333333) << 2 | (x>>2) & 0x33333333 ; 
    4.     x = (x & 0x0f0f0f0f) << 4 | (x>>4) & 0x0f0f0f0f ; 
    5.     x = (x<<24) | ((x&0xff00)<<8) | ((x>>8) & 0xff00) | (x>>24) ; 
    6.     return x ;
    7. }
     
  • 相关阅读:
    YYC松鼠视频pro版安装实操001
    YYC松鼠视频短信对接教程
    此处指讲解自定义的一些目录结构及组件-yyc松鼠短视频系统
    APP启动无视频数据-YYC松鼠短视频系统
    后台提示登录失败----YYC松鼠短视频开源
    C++静态成员变量和静态成员函数
    内联函数和宏定义的区别
    C++中的接口继承和实现继承
    拷贝构造函数(define)
    类的封装
  • 原文地址:https://www.cnblogs.com/yuandongtao1989/p/6681802.html
Copyright © 2020-2023  润新知