用%f来给double类型赋值问题

本文探讨了在C/C++中使用%f与%lf输入double类型数据时的问题,解释了为何float与double类型在输入时会出现不同的结果,并强调了变量初始化的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

下面代码,不论输入x为何值,输出结果都是一个很大的不符合预期的值。
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

但是

1)如果将double类型换成float类型即可得到想要的结果。在这里插入图片描述
2)如果将double类型的x先初始化为0 也可以得到想要结果
在这里插入图片描述

分析:

以最初的代码,x = 0为例,一步步调试。发现,当输入x的值为0是,内存中x实际存储的并不是0,而是一个很奇怪的数字。
在这里插入图片描述
这是因为:
在这里插入图片描述
正确写法应该将%f换成%lf。如果将double转换为float也可以得到想要结果 ,不过会发生数据的截断。

监视下如果用%f来给double类型数据赋值会发生什么
(double八字节,float 四字节) 观察x的内存变化

其实cc也是中文编码里面的“烫”,平时文件里面的“烫”字的出现,就是因为没有赋初值的缘故
在这里插入图片描述
输入0后在这里插入图片描述
因为用%f,即float类型进行输入,所以只会改变是前四个字节(float四字节)变为0 ,后面的四个字节不变 ,所以x的值为
在这里插入图片描述
如果将x先初始化的话 ,x会变为00 00 00 00 00 00 00 00 即使用%f来录入也可以得到想要的结果(只是输入数据的大小范围还是float型)。

建议在定义变量的时候最好都先初始化,因为你不知道内存中会存放什么内容,尤其是在申请内存开辟 空间时,在使用前都应该先将内存初始化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值