printf函数中类型转换和不对应控制符读取

printf函数中类型转换和不对应控制符读取,第1张

我们知道,C一般在运算时,若参与运算量的类型不同,为了保证数据精度不丢失,会先转换成同一类型,然后进行运算(如int*float=float,int*double=double)


如下,在printf函数中4*0.5本应自动转换4为4.0进行运算,结果本应该为2.0,但以%d控制符输出时结果为什么是0呢

#include
int main(){
	
	int m;
	m=4;  
    
	printf("%f   %d\n",m*0.5,m*0.5);	
	
	return 0;
}

输出:  2.000000     0


printf函数中则不会进行类型转换,它是按照%d,%f等控制字符提示的格式从内存中读出你所提供的元素的值,在C语言中,int类型是32bit,而float一般是64bit。



而4*0.2的结果会被强制转化为2.000000(浮点型),用%f读取自然可以正常输出,即完全读取0000 0000 0000 0010;而%d读取只会读区低的8个位,即0000 0000,所以输出0。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/565223.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-04-06
下一篇2022-04-06

发表评论

登录后才能评论

评论列表(0条)

    保存