野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 10782|回复: 3

数据转换的问题

[复制链接]
发表于 2017-5-22 09:42:54 | 显示全部楼层 |阅读模式
今天在做程序测试的时候,发现一个小小的疑惑,希望大家能帮忙讨论下。在程序中需要将float型数据取整数,但是对于不同的float型数据转换的结果却是不一样的,下面将代码贴出来
                        int8_t a=(int8_t)h;
                        printf("a=%d\r\n",a);
                        float32_t b=-194.667953f;
                        int8_t i=(int8_t)b;
                        printf("i=%d\r\n",i);
下面是串口助手打印结果:
                      a=-1
                      i=62
很明显i=62不是我想要的结果;紧接着我把代码改成如下所示,代码如下;
                        float32_t h=-1.47f;
                        int16_t a=(int16_t)h;
                        printf("a=%d\r\n",a);
                        float32_t b=-194.667953f;
                        int16_t i=(int16_t)b;
                        printf("i=%d\r\n",i);

下面是串口打印的结果:a=-1
                                i=-194
是符合我的预期的,随后我将int_16改为int32_t也得到了我想要的结果。但我查阅了资料后发现浮点数转换成整形数是直接舍去小数的,为何在这里得到了不同的结果,还请各位指正
回复

使用道具 举报

发表于 2017-5-22 10:45:58 | 显示全部楼层
帮顶              
回复 支持 反对

使用道具 举报

发表于 2017-5-22 12:57:24 | 显示全部楼层
int8_t 范围是-128~127
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-22 16:49:12 | 显示全部楼层
zhlpan1212 发表于 2017-5-22 12:57
int8_t 范围是-128~127

哈哈哈哈,对哦。谢谢兄台,咋就没想到呢
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2025-1-16 02:53 , Processed in 0.033694 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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