OpenEdv-开源电子网

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

float数据如何转化成字节数组

[复制链接]

5

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
440
金钱
440
注册时间
2016-11-7
在线时间
63 小时
发表于 2017-7-19 12:42:10 | 显示全部楼层 |阅读模式
1金钱
如题 MDK编译环境

最佳答案

查看完整内容[请看2#楼]

float a = 3.14159; uint8_t temp[4]; temp[0] = *(uint8_t *)&a; temp[1] = *(uint8_t *)(&a + 1); temp[2] = *(uint8_t *)(&a + 2); temp[3] = *(uint8_t *)(&a + 3); 没考虑大小端的问题,可根据需要调整数组下标的顺序。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

21

主题

151

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
423
金钱
423
注册时间
2017-4-1
在线时间
73 小时
发表于 2017-7-19 12:42:11 | 显示全部楼层
float a = 3.14159;
uint8_t temp[4];
temp[0] = *(uint8_t *)&a;
temp[1] = *(uint8_t *)(&a + 1);
temp[2] = *(uint8_t *)(&a + 2);
temp[3] = *(uint8_t *)(&a + 3);
没考虑大小端的问题,可根据需要调整数组下标的顺序。
回复

使用道具 举报

2

主题

685

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3448
金钱
3448
注册时间
2017-7-4
在线时间
869 小时
发表于 2017-7-19 13:55:09 | 显示全部楼层
1、
union u_data
{
       char a[4];
       float i;
}A;
float i 内容在A.a里面;
2、
float i;
char *a;
a = (char*)&i;
a指向float i 内存首地址,依次取得每个字节地址内容。
回复

使用道具 举报

3

主题

130

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3132
金钱
3132
注册时间
2017-3-2
在线时间
324 小时
发表于 2017-7-19 13:58:19 | 显示全部楼层
float aa = 3.141593;
u8 temp[4];
u32 bb;  
bb = *(u32*)&aa;  
temp[0] = (bb >> 24) & 0xff;
temp[1] = (bb >> 16) & 0xff;
temp[2] = (bb >> 8) & 0xff;
temp[3] = bb & 0xff;
坚持不懈的努力!
回复

使用道具 举报

3

主题

130

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3132
金钱
3132
注册时间
2017-3-2
在线时间
324 小时
发表于 2017-7-19 14:00:54 | 显示全部楼层
3.141593=>0x40490FDC  转换后 temp[0]=0x40;temp[1]=0x49;temp[2]=0x0F;temp[3]=0xDC;
坚持不懈的努力!
回复

使用道具 举报

2

主题

35

帖子

0

精华

初级会员

Rank: 2

积分
186
金钱
186
注册时间
2017-6-30
在线时间
43 小时
发表于 2018-9-19 11:24:03 | 显示全部楼层
bucker 发表于 2017-7-19 12:42
float a = 3.14159;
uint8_t temp[4];
temp[0] = *(uint8_t *)&a;

        感觉应该是这样
        temp[0] = *(uint8_t *)&aa;
                temp[1] = *((uint8_t *)&aa + 1);
                temp[2] = *((uint8_t *)&aa + 2);
                temp[3] = *((uint8_t *)&aa + 3);
回复

使用道具 举报

24

主题

106

帖子

0

精华

高级会员

Rank: 4

积分
637
金钱
637
注册时间
2018-7-13
在线时间
197 小时
发表于 2018-9-19 14:08:12 | 显示全部楼层
本帖最后由 不學會32不改名 于 2018-9-19 14:09 编辑
bucker 发表于 2017-7-19 12:42
float a = 3.14159;
uint8_t temp[4];
temp[0] = *(uint8_t *)&a;


float a = 3.14159;
uint8_t temp[4];
temp[0] = *(uint8_t *)&a;
temp[1] = *((uint8_t *)(&a) + 1);
temp[2] = *((uint8_t *)(&a )+ 2);
temp[3] = *((uint8_t *)(&a) + 3);

老哥觉得这样如何? IAR的大小端 低字节在前。
回复

使用道具 举报

4

主题

133

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3863
金钱
3863
注册时间
2016-6-11
在线时间
710 小时
发表于 2018-9-19 20:33:49 | 显示全部楼层
本帖最后由 jxcrgt35 于 2018-9-19 20:37 编辑

float a=3.14159;
unsigned char buff[4];
memcpy(buff,(unsigned char *)&a,4);
回复

使用道具 举报

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
发表于 2018-9-20 21:32:27 | 显示全部楼层
设为最佳答案的这个回答可能是错误的。&a+1到底指向哪里?我的直觉不是下个字节,而是加了4字节,因为float在这里是4字节32位的浮点数。
回复

使用道具 举报

24

主题

106

帖子

0

精华

高级会员

Rank: 4

积分
637
金钱
637
注册时间
2018-7-13
在线时间
197 小时
发表于 2018-9-21 08:05:55 | 显示全部楼层
xiatianyun 发表于 2018-9-20 21:32
设为最佳答案的这个回答可能是错误的。&a+1到底指向哪里?我的直觉不是下个字节,而是加了4字节,因为float ...

确实是错的,按照最佳的写法,这个float的长度已经达到16个字节了
回复

使用道具 举报

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
发表于 2018-9-21 15:52:15 | 显示全部楼层
我试验了下,应该是:
float a = 3.14159;
uint8_t temp[4];
char* pt = &a;
temp[0] = *pt;
temp[1] = *(pt+1);
temp[2] = *(pt +2);
temp[3] = *(pt + 3);
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-19 22:15

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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