OpenEdv-开源电子网

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

类型转换的问题。。。

[复制链接]

8

主题

34

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2014-11-28
在线时间
0 小时
发表于 2014-12-4 23:46:50 | 显示全部楼层 |阅读模式
5金钱
我将这行代码
temp=(float)adcx*(3.3/4096)
改为
temp=(float)adcx*(0.0008)

为什会报这个警告呢
main.c(274): warning:  #1035-D: single-precision operand implicitly converted to double-precision

最佳答案

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

就是单精度转换成双精度了。 你试试double
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2014-12-4 23:46:51 | 显示全部楼层
就是单精度转换成双精度了。
你试试double
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

34

主题

805

帖子

4

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1863
金钱
1863
注册时间
2011-3-29
在线时间
139 小时
发表于 2014-12-5 01:54:57 | 显示全部楼层
单精度的(float)adcx乘以双精度的浮点数,结果隐式转换为双精度数。
业余程序玩家。
回复

使用道具 举报

8

主题

34

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2014-11-28
在线时间
0 小时
 楼主| 发表于 2014-12-5 09:43:48 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
问题解决了,哈哈。谢谢。
回复

使用道具 举报

22

主题

2251

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4471
金钱
4471
注册时间
2013-4-22
在线时间
335 小时
发表于 2014-12-5 14:54:03 | 显示全部楼层
0.0008改为0.0008f试试看,arm的编译器通常在计算浮点数乘除法时转成双精度的计算,其实可以强制转化为float去计算,这样还可以减少代码空间,增加程序执行效率
回复

使用道具 举报

8

主题

34

帖子

0

精华

初级会员

Rank: 2

积分
87
金钱
87
注册时间
2014-11-28
在线时间
0 小时
 楼主| 发表于 2014-12-6 00:49:54 | 显示全部楼层
回复【5楼】三叶草:
---------------------------------
这样也可以,在后面加F就是强制单精度计算吗?
回复

使用道具 举报

22

主题

2251

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4471
金钱
4471
注册时间
2013-4-22
在线时间
335 小时
发表于 2014-12-8 09:35:22 | 显示全部楼层
回复【6楼】Nemo_gg:
---------------------------------
这个是和编译器有关系的
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-23 09:17

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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