六十六 位操作 0x1 << 3

来源:互联网 发布:ai是什么软件 编辑:程序博客网 时间:2024/05/22 00:45

 #define   BIT3   (0x1   <<   3)   
    static   int   a;   
      
    void   set_bit3(void)     
    {   
            a   |=   BIT3;   
    }   
    void   clear_bit3(void)     
    {   
            a   &=   ~BIT3;   
    }

用   #defines   和   bit   masks   操作。这是一个有极高可移植性的方法,是应该被用到的方法。      

0x表示此数为16进制表示方法 
0x1表示为2进制就是0001 
<<是移位操作 表示左移,>>表示右移
0x1<<3表示将0x1向左移3位 
即0x1<<3 = 0001<<3 = 1000 = 0x8

a |= BIT3 相当 a = a | BIT3 相当 a = a | 0x0008; 
a &= ~BIT3 相当 a = a & ~BIT3 相当 a = a & 0xFFF7;

 

#define BIT_MASK(bit_pos) (0x01<<(bit_pos))

函数:

int bit_set(unsigned int *val,unsigned char pos)

{

    if(pos>=sizeof(unsigned int)*8)

    {

          return 0;

    }

     *val=(*val&~BIT_MASK(pos));

    return 1;

}

实现高低字位交换函数:

#include<iostream>
#include<string>
using namespace std;
int main()
{
unsigned short a=0xABCD;
unsigned short b,c,d;
b=(a<<8)&0xff00;
c=(a>>8)&0x00ff;
d=c|b;
printf("%x",d);//cdab
}

0 0
原创粉丝点击