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

问题描述

下面代码,不论输入x为何值,输出结果都是一个很大的不符合预期的值。
用%f来给double类型赋值问题_第1张图片

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

但是

1)如果将double类型换成float类型即可得到想要的结果。用%f来给double类型赋值问题_第2张图片
2)如果将double类型的x先初始化为0 也可以得到想要结果
用%f来给double类型赋值问题_第3张图片

分析:

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

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

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

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

你可能感兴趣的:(c基础)