mokongking

C语言:位(bit)与字节(byte)之间的转换

1. 取出一个字节(byte)中的每一位(bit)
代码如下:

复制代码
uint8_t    Data = 0x52;

uint8_t n[8]={0};

//方法1:
n[0] = (Data & 0x01) == 0x01 ? 1 : 0;    //等于0
n[1] = (Data & 0x02) == 0x02 ? 1 : 0;    //等于1
n[2] = (Data & 0x04) == 0x04 ? 1 : 0;    //等于0
n[3] = (Data & 0x08) == 0x08 ? 1 : 0;    //等于0
n[4] = (Data & 0x10) == 0x10 ? 1 : 0;    //等于1
n[5] = (Data & 0x20) == 0x20 ? 1 : 0;    //等于0
n[6] = (Data & 0x40) == 0x40 ? 1 : 0;    //等于1
n[7] = (Data & 0x80) == 0x80 ? 1 : 0;    //等于0

//方法2:
int i;
for(i=0;i<8;i++)
{
n[i] = (Data & (0x01<<i)) == (0x01<<i) ? 1 : 0;
}
复制代码

 

2. 将八个数据位合并成一个字节
代码如下:

复制代码
uint8_t    Data = 0x00;

uint8_t n[8]={0,1,0,0,1,0,1,0};

//方法1:
Data = n[0]|(n[1]<<1)|(n[2]<<2)|(n[3]<<3)|(n[4]<<4)|(n[5]<<5)|(n[6]<<6)|(n[7]<<7);
//Data等于0x52

//方法2:
int i;
for(i=0;i<8;i++)
{
Data |= n[i]<<i;    
}
复制代码

 

链接:https://blog.csdn.net/MQ0522/article/details/110229251

posted on   虎啸岳林  阅读(1438)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!

导航

统计信息

点击右上角即可分享
微信分享提示