OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7851|回复: 2

关于16位数据提取高八位低八位的问题求助

[复制链接]

7

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
76
金钱
76
注册时间
2012-9-18
在线时间
0 小时
发表于 2013-5-10 09:33:36 | 显示全部楼层 |阅读模式

 看到这样一个宏定义

#define BYTE0(dwTemp)       (*(char *)(&dwTemp))
#define BYTE1(dwTemp)       (*((char *)(&dwTemp) + 1))
#define BYTE2(dwTemp)       (*((char *)(&dwTemp) + 2))
#define BYTE3(dwTemp)       (*((char *)(&dwTemp) + 3))
这样如果dwTemp是一个16位的数据的话,那么通过以上的宏定义就能读取它的低八位和高八位吗?没有理解,忘各位大神指点迷津。

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

11

主题

53

帖子

0

精华

初级会员

Rank: 2

积分
188
金钱
188
注册时间
2012-6-20
在线时间
38 小时
发表于 2013-5-10 09:47:30 | 显示全部楼层
union 
{
unsigned int INT16;
struct
{
unsigned int L8: 8;    //定时器1缓冲区低8位
unsigned int H8: 8;    //定时器1缓冲区高8位
}Bits;
}Time; //定时器1缓冲区
自己好好研究。
回复 支持 反对

使用道具 举报

7

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
76
金钱
76
注册时间
2012-9-18
在线时间
0 小时
 楼主| 发表于 2013-5-10 09:55:42 | 显示全部楼层
回复【2楼】wufuhai216:
---------------------------------
谢谢,刚刚在网上找到了正解,其大致意思就是char是一个字节的,char*就是强制转换为字节指针,所以其偏移量按字节偏移,因此加上偏移量就可以具体得到某字节的数据。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-21 11:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表